Rucksackproblem - LinkFang.de





Rucksackproblem


Das Rucksackproblem (engl. auch knapsack problem) ist ein Optimierungsproblem der Kombinatorik. Aus einer Menge von Objekten, die jeweils ein Gewicht und einen Nutzwert haben, soll eine Teilmenge ausgewählt werden, deren Gesamtgewicht eine vorgegebene Gewichtsschranke nicht überschreitet. Unter dieser Bedingung soll der Nutzwert der ausgewählten Objekte maximiert werden.

Die Entscheidungsvariante des Rucksackproblems fragt, ob ein zusätzlich vorgegebener Nutzwert erreicht werden kann. Sie gehört zur Liste der 21 klassischen NP-vollständigen Probleme, von denen Richard Karp 1972 die Zugehörigkeit zu dieser Klasse zeigen konnte.

In der Kryptographie wird häufig eine andere Entscheidungsvariante betrachtet. Dabei werden nur die Gewichte betrachtet und es wird gefragt, ob es eine Teilmenge der Objekte gibt, die einen vorgegebenen Gewichtswert genau erreicht. Diese Problemvariante wird auch als SUBSET-SUM bezeichnet. Basierend auf dieser Variante wurde das Public-Key-Kryptoverfahren Merkle-Hellman-Kryptosystem entwickelt, das sich allerdings als nicht besonders sicher herausstellte.

Anschauung

Das Rucksackproblem hat seinen Namen aus folgender Anschauung heraus erhalten: Es sind verschiedene Gegenstände mit einem bestimmten Gewicht und einem Nutzwert gegeben. Aus diesen Gegenständen soll nun eine Auswahl getroffen werden, die in einen Rucksack mit einer vorgegebenen Gewichtsschranke mitgenommen werden können. In der Literatur wird zur Veranschaulichung auch gerne der Dieb herangezogen, der nur einen kleinen Teil der Beute im Rucksack abtransportieren kann und nun versucht, das Maximum an Nutzwert herauszuschlagen.

Mathematische Formulierung

Gegeben ist eine endliche Menge von Objekten [math]U[/math]. Durch eine Gewichtsfunktion [math]w[/math] und die Nutzenfunktion [math]v[/math] wird den Objekten ein Gewicht und ein festgelegter Nutzwert zugeordnet:

[math]w:U\rightarrow\mathbb{R}[/math]
[math]v:U\rightarrow\mathbb{R}[/math]

Des Weiteren gibt es eine vorgegebene Gewichtsschranke [math]B \in\mathbb{R}[/math].

Gesucht ist eine Teilmenge [math]K\subseteq U[/math], die die Bedingung

[math]\sum_{u\in K} w(u) \le B[/math] einhält und die Zielfunktion [math]\sum_{u\in K} v(u)[/math] maximiert.

Lösung mittels einer dynamischen Programmierung

Sind die Gewichte ganzzahlig, so lässt sich der optimale Wert des Rucksackproblems auch mittels dynamischer Programmierung lösen. Seien dazu [math]1,\ldots,n[/math] die Elemente von [math]U[/math].

  1. Eingabe: U, B, w, v wie oben beschrieben
  2.   R := [1…(n+1), 0…B]-Matrix, mit Einträgen 0
  3.   FOR i = n … 1
  4.     FOR j = 1 … B
  5.       IF w(i) <= j
  6.         R[i,j] := max( v(i) + R[i+1, j-w(i)], R[i+1,j] )
  7.       ELSE
  8.         R[i,j] := R[i+1,j]
  9. Ausgabe: R[1,B]

In jeder Speicherzelle [math]R(i,j)[/math] ist der maximale Nutzwert bei maximal möglichem Gesamtgewicht von [math]j[/math] bei Berücksichtigung einer Teilmenge von Gegenständen aus der Teilsequenz [math][i..n][/math] der Gesamtsequenz aller Gegenstände [math][1..n][/math]. Also ist der maximale Nutzwert bei Berücksichtigung einer Teilmenge aller Gegenstände in der Zelle [math]R(1, B)[/math] nach Beendigung des Algorithmus gespeichert.

In jeder Zeile [math]i[/math] der Matrix [math]R[/math] wird über die beiden Fälle optimiert, ob der Nutzwert maximal vergrößert werden kann, wenn der Gegenstand [math]i[/math] mit dem Gewicht [math]w(i)[/math] dem Rucksack hinzugefügt oder er nicht aufgenommen wird. Im ersten Fall erhöht sich der Nutzwert um [math]v(i)[/math].

Um den Inhalt des Rucksacks mit dem maximalen Nutzwert zu bestimmen, kann er rekonstruiert werden, indem die Berechnung des Optimums in [math]R(1,B)[/math] mittels Backtracking zurückverfolgt wird.

Die Korrektheit folgt aus der folgenden Beobachtung:

Sei [math]K^\star[/math] eine optimale Lösung. Dann ist [math]K^\star\backslash\{i\}[/math] eine optimale Lösung für die Instanz [math]U\backslash\{i\}[/math] mit Maximalgewicht [math]B-w(i)[/math]. Der Algorithmus benötigt aufgrund der verschachtelten for-Schleifen, die über n und B iterieren, eine Laufzeit von [math]O(n\cdot B)[/math]. Hierbei ist zu beachten, dass B eine zu seiner Eingabelänge exponentiell wachsende Größe und somit die Laufzeit pseudopolynomiell ist.

Anwendungen

Viele reale Situationen lassen sich mit Hilfe der Lösung dieses Problems mathematisch klären. Oft steht eine begrenzte Kapazität zur Verfügung, welche nicht die gesamte Nachfrage befriedigen kann. Man denke z. B. an einen Lkw, der viele verschiedene Güter – mit einem bestimmten Gewinn – transportieren soll, aber wegen der begrenzten Lademenge nicht alle Güter aufnehmen kann. Der Besitzer des Lkws wird die Ladung so wählen wollen, dass der Gewinn maximal ausfällt.

Siehe auch

Literatur

Weblinks


Kategorien: Dynamische Programmierung | Komplexitätstheorie | Optimierung

Quelle: Wikipedia - http://de.wikipedia.org/wiki/Rucksackproblem (Vollständige Liste der Autoren des Textes [Versionsgeschichte])    Lizenz: CC-by-sa-3.0

Änderungen: Alle Bilder mit den meisten Bildunterschriften wurden entfernt. Ebenso alle zu nicht-existierenden Artikeln/Kategorien gehenden internen Wikipedia-Links (Bsp. Portal-Links, Redlinks, Bearbeiten-Links). Entfernung von Navigationsframes, Geo & Normdaten, Mediadateien, gesprochene Versionen, z.T. ID&Class-Namen, Style von Div-Containern, Metadaten, Vorlagen, wie lesenwerte Artikel. Ansonsten sind keine Inhaltsänderungen vorgenommen worden. Weiterhin kann es durch die maschinelle Bearbeitung des Inhalts zu Fehlern gerade in der Darstellung kommen. Darum würden wir jeden Besucher unserer Seite darum bitten uns diese Fehler über den Support mittels einer Nachricht mit Link zu melden. Vielen Dank!

Stand der Informationen: August 201& - Wichtiger Hinweis: Da die Inhalte maschinell von Wikipedia übernommen wurden, ist eine manuelle Überprüfung nicht möglich. Somit garantiert LinkFang.de nicht die Richtigkeit und Aktualität der übernommenen Inhalte. Sollten die Informationen mittlerweile fehlerhaft sein, bitten wir Sie darum uns per Support oder E-Mail zu kontaktieren. Wir werden uns dann innerhalb von spätestens 10 Tagen um Ihr Anliegen kümmern. Auch ohne Anliegen erfolgt mindestens alle drei Monate ein Update der gesamten Inhalte.