CATEGORII DOCUMENTE |
Fie n numere pozitive S wi> wi wj i j si M>
Sa se determine toate multimile S` S cu =M
Folosim notatia solutiei sub forma X= xi=0 sau 1
wi=M
Arborele spatiului starilor va fi de forma:
Consideram w1,w2.wn in ordine crescatoare (fara a fi o restrictie generala)
Functia de marginire
Bk(x1,x2,.xk) = true if ( + M and wi + wk+1 M)
wi-cresc.
= false - altfel
SumSubset(s,k,r);
//(x1,x2,.xn) - vectorul solutie . Psp. x1,.,xk-1 calculati
s =wi r =
//Psp. w1 M si M [ deci initial (k=1) Bk-1 = true ]
}
return
Observatie:
Functia intra in executie ,avind asigurate conditiile Bk-1=true : s+wk M si s+r M.
Initial w1 M si 0+ M corespunzind apelului SumSubset (0,1,)
Aceste conditii sint asigurate la apelul recursiv.
Nu se verifica explicit k>n deoarece initial s = 0 < M si s+r M. Rezulta r 0 deci k nu poate depasi n. De asemenea in linia (*) deoarece s+wk < M si s+r M rezulta r wk, deci k+1 n.
Politica de confidentialitate | Termeni si conditii de utilizare |
Vizualizari: 1300
Importanta:
Termeni si conditii de utilizare | Contact
© SCRIGROUP 2024 . All rights reserved