Preprosti problem nahrbtnika
Preprosti problem nahrbtnika je računalniški problem, s katerim poskusimo zapolniti nahrbtnik z danimi predmeti, ki ima vsak svojo ceno in prostornino. Bodisi gre za dejansko polnjenje nahrbtnika, polnjenje nakupovalne vreče, zlaganje predmetov v avto. Deluje po principu, da bi karseda najbolje zapolnili prostor in vzeli dražje predmete s seboj.
Slabo polnjenje nahrbtnika je takrat, ko kar po vrsti polnimo nahrbtnik. Nahrbtnik bo hitro napolnjen in v njem je lahko samo en predmet, ki je sam po sebi sicer pomemben, zasede pa toliko prostora, da če bi dali namesto njega druga dva predmeta, ki sta manj pomembna, bi imeli več od vsebine nahrbtnika. Torej predmete najprej uredimo po njihovi pomembnosti in po prostoru, ki ga zasedejo.
Opis problema
Imamo nahrbtnik s podano prostornino V in n predmetov, pri čemer za vsak predmet svojo vrednost C[i] in prostornino v[i]. V nahrbtnik želimo straviti predmete dokler je v njem še kaj prostora in po načelu, da je v nahrbtniku čim večja vrednost. Predmete lahko režemo pri pogojih in če je
- .
Dopustna rešitev oziroma dopustna množica je v tem primeru kakršna koli množica rešitev , ki izpolnjuje te pogoje.
Optimalna rešitev pa je tista dopustna rešitev, pri kateri ima največjo vrednost.
Postopek algoritma
Predmete najprej uredimo po vrednosti , torej od največje vrednosti do najmanjše. Nato pa dajemo predmete v nahrbtnik, dokler gredo celi vanj. Ko naletimo na prvi predmet, ki ne gre več v nahrbtnik, ga režemo in sicer tako, da nahrbtnik napolnimo, ostale predmete pa ne damo v nahrbtnik, torej je .
Zahtevnost
Zanka se izvrši največkrat n krat, saj lahko v skrajnjem primeru damo v nahrbtnik vseh n predmetov, zato je časovna zahtevnost tega algoritma O(n)
Splošna procedura
procedure Napolni (V, n, v, c, x) begin for i:= 1 to n do x[i] := 0 prostor := V i := 1 repeat if v[i] > prostor then exit (repeat) else begin x[i] := 1 // i-ti predmed se gre v nahrbtnik prostor := prostor - v[i] end i:= i + 1 until i>n if i<=n then x[i] := prostor / v[i] //prvi predmet, ki ne gre cel noter, razdelimo end