Heim >Backend-Entwicklung >C++ >Wie können wir mithilfe des Rucksack-Algorithmus die spezifischen Gegenstände identifizieren, die in einem Rucksack enthalten sind?
Bestimmen von Gegenständen im Rucksack mithilfe des Rucksack-Algorithmus
Der Rucksack-Algorithmus, eine Optimierungstechnik, wird häufig verwendet, um den optimalen Wert von Gegenständen zu bestimmen die in einem Rucksack mit begrenztem Fassungsvermögen Platz finden. Um jedoch eine umfassende Lösung zu erhalten, ist es häufig wünschenswert, nicht nur den optimalen Wert, sondern auch die spezifischen im Rucksack enthaltenen Artikel zu identifizieren.
Um den bereitgestellten Code zu verbessern, kann ein zusätzliches Array zur Aufzeichnung verwendet werden ausgewählte Artikel. Der geeignete Schritt zur Durchführung dieser Auswahl erfolgt während des iterativen Prozesses des Algorithmus.
Überprüfen Sie nach jeder Iteration, ob die Differenz zwischen dem aktuellen Gewicht im Rucksack (dpw) und dem vorherigen Gewicht ohne den aktuellen Artikel (dp.) [w - items[j-1].getWeight()][j-1]) ist gleich dem Gewicht des aktuellen Artikels. Wenn diese Bedingung erfüllt ist, wurde das Element ausgewählt und sollte dem Array hinzugefügt werden.
Alternativ besteht ein einfacher Ansatz darin, nach der Bestimmung des optimalen Werts rückwärts durch die Matrix zu gehen. Wenn die Differenz zwischen dem aktuellen Gewicht im Rucksack (dpline) und dem vorherigen Gewicht ohne den aktuellen Artikel (dpline - Gewicht(i)) genau dem Wert des aktuellen Artikels (Wert(i)) entspricht, zeigt dies an, dass der Der Artikel befindet sich im Rucksack und sollte als solcher gekennzeichnet sein. Dieser Vorgang wird fortgesetzt, bis alle Elemente überprüft wurden.
Das obige ist der detaillierte Inhalt vonWie können wir mithilfe des Rucksack-Algorithmus die spezifischen Gegenstände identifizieren, die in einem Rucksack enthalten sind?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!