<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="de">
	<id>https://wiki-de.moshellshocker.dns64.de/index.php?action=history&amp;feed=atom&amp;title=Beh%C3%A4lterproblem</id>
	<title>Behälterproblem - Versionsgeschichte</title>
	<link rel="self" type="application/atom+xml" href="https://wiki-de.moshellshocker.dns64.de/index.php?action=history&amp;feed=atom&amp;title=Beh%C3%A4lterproblem"/>
	<link rel="alternate" type="text/html" href="https://wiki-de.moshellshocker.dns64.de/index.php?title=Beh%C3%A4lterproblem&amp;action=history"/>
	<updated>2026-05-28T21:40:09Z</updated>
	<subtitle>Versionsgeschichte dieser Seite in Wikipedia (Deutsch) – Lokale Kopie</subtitle>
	<generator>MediaWiki 1.43.8</generator>
	<entry>
		<id>https://wiki-de.moshellshocker.dns64.de/index.php?title=Beh%C3%A4lterproblem&amp;diff=114262&amp;oldid=prev</id>
		<title>90.187.14.241: /* Algorithmen */</title>
		<link rel="alternate" type="text/html" href="https://wiki-de.moshellshocker.dns64.de/index.php?title=Beh%C3%A4lterproblem&amp;diff=114262&amp;oldid=prev"/>
		<updated>2025-06-05T10:24:19Z</updated>

		<summary type="html">&lt;p&gt;&lt;span class=&quot;autocomment&quot;&gt;Algorithmen&lt;/span&gt;&lt;/p&gt;
&lt;p&gt;&lt;b&gt;Neue Seite&lt;/b&gt;&lt;/p&gt;&lt;div&gt;Das &amp;#039;&amp;#039;&amp;#039;Behälterproblem&amp;#039;&amp;#039;&amp;#039; oder auch &amp;#039;&amp;#039;&amp;#039;bin packing problem&amp;#039;&amp;#039;&amp;#039; ist ein [[Kombinatorische Optimierung|kombinatorisches Optimierungsproblem]], das auf folgender Fragestellung basiert:&lt;br /&gt;
* &amp;#039;&amp;#039;Gegeben:&amp;#039;&amp;#039; Eine Anzahl &amp;lt;math&amp;gt;k \in \mathbb{N}&amp;lt;/math&amp;gt; von „Behältern“ ([[Englische Sprache|englisch]] &amp;#039;&amp;#039;bin&amp;#039;&amp;#039;) der Größe &amp;lt;math&amp;gt;b \in \mathbb{N}&amp;lt;/math&amp;gt; und eine Anzahl &amp;lt;math&amp;gt;n \in \mathbb{N}&amp;lt;/math&amp;gt; „Objekte“ mit den Größen &amp;lt;math&amp;gt; a_1,a_2,\dotsc,a_n\ \leq\ b &amp;lt;/math&amp;gt;.&lt;br /&gt;
* &amp;#039;&amp;#039;Frage:&amp;#039;&amp;#039; Können die &amp;lt;math&amp;gt;n&amp;lt;/math&amp;gt; „Objekte“ so auf die &amp;lt;math&amp;gt;k&amp;lt;/math&amp;gt; „Behälter“ verteilt (&amp;#039;&amp;#039;packing&amp;#039;&amp;#039;) werden, dass keiner der „Behälter“ überläuft? Formal:&lt;br /&gt;
::&amp;lt;math&amp;gt; \exists\ f\colon \{1,\dotsc,n\} \to \{1,\dotsc,k\}\text{, so dass für alle } j \in \{1,\dotsc,k\} \quad \sum_{f(i)=j} a_i \leq b \text{  gilt?}&amp;lt;/math&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Das oben beschriebene [[Entscheidungsproblem]] ist [[NP-Vollständigkeit|NP-vollständig]]; das zugehörige [[Optimierungsproblem]] –&amp;amp;nbsp;das Finden einer Zuordnung, bei der die Anzahl an Behältern minimiert wird&amp;amp;nbsp;– ist [[NP-Schwere|NP-schwer]].&lt;br /&gt;
&lt;br /&gt;
Die hier gegebene Formulierung des Bin-Packing-Problems ist nur die Motivation beziehungsweise Basis für eine Vielzahl weiterer &amp;#039;&amp;#039;Packing-Problems&amp;#039;&amp;#039;, die unter anderem in der [[Verpackung]]sindustrie eine große Rolle spielen.&lt;br /&gt;
&lt;br /&gt;
Eine etwas allgemeiner formale Definition beschreibt das Bin-Packing-Problem als die Bestimmung einer [[Partition (Mengenlehre)|Partition]] und Zuordnung einer [[Menge (Mathematik)|Menge]] von Objekten, so dass eine bestimmte Bedingung erfüllt bzw. eine Zielfunktion minimiert oder maximiert wird.&lt;br /&gt;
&lt;br /&gt;
Man unterscheidet zwischen Offline- und Online-Varianten, wobei offline bedeutet, dass im Voraus alle Objekte bekannt sind. Bei Online-Verfahren muss sofort entschieden werden, in welchen Behälter das Objekt gepackt wird, ohne die folgenden Objekte zu kennen.&lt;br /&gt;
&lt;br /&gt;
== Algorithmen ==&lt;br /&gt;
&lt;br /&gt;
Da Bin-Packing ein NP-schweres Problem ist, ist es [[P-NP-Problem|vermutlich]] unmöglich, es in polynomialer Laufzeit zu lösen. Johnsons [[Approximationsalgorithmus]] &amp;#039;&amp;#039;First Fit Decreasing&amp;#039;&amp;#039; löst das Problem in polynomieller Zeit mit einer asymptotischen [[Gütegarantie]] von &amp;lt;math&amp;gt;11 \over 9&amp;lt;/math&amp;gt;.&lt;br /&gt;
&lt;br /&gt;
# Sortiere die Objekte nach absteigender Größe&lt;br /&gt;
# Füge die Objekte der Reihe nach ein, sodass jedes in den ersten Behälter gegeben wird, in dem noch genug Platz ist.&lt;br /&gt;
# Falls in keinem der bereits geöffneten Behälter genügend Platz ist, öffne einen neuen.&lt;br /&gt;
&lt;br /&gt;
Die Laufzeit beträgt &amp;lt;math&amp;gt;\mathcal O(n\cdot\log n)&amp;lt;/math&amp;gt; (sowohl für das Sortieren, als auch für das Einfügen).&lt;br /&gt;
Dieselben Resultate gelten auch für &amp;#039;&amp;#039;Best Fit Decreasing&amp;#039;&amp;#039;. Dabei wird ein Objekt nicht in den ersten Behälter eingefügt, in den es passt, sondern in den Behälter, in den es gerade noch passt (die Restkapazität wird also minimiert).&lt;br /&gt;
&lt;br /&gt;
Bei der Online-Variante ist es nicht möglich, die Objekte im Voraus nach Größe zu sortieren. Die Algorithmen &amp;#039;&amp;#039;First Fit&amp;#039;&amp;#039; und &amp;#039;&amp;#039;Best Fit&amp;#039;&amp;#039; arbeiten analog zu den oben genannten, jedoch ohne vorheriges Sortieren. Beide [[Algorithmus|Algorithmen]] haben eine scharfe asymptotische Gütegarantie von 1,7 und eine Laufzeit von &amp;lt;math&amp;gt;\mathcal O(n\cdot\log n)&amp;lt;/math&amp;gt;. &amp;#039;&amp;#039;Best Fit&amp;#039;&amp;#039; sucht in allen bisher vorhandenen Behältern nach dem kleinsten noch passenden freien Platz.&lt;br /&gt;
&lt;br /&gt;
Der naive Algorithmus &amp;#039;&amp;#039;Next Fit&amp;#039;&amp;#039; packt die Objekte der Reihe nach in den letzten geöffneten Behälter, falls sie hineinpassen. Ansonsten wird der Behälter geschlossen, ein neuer geöffnet und das aktuelle Objekt in den leeren Behälter gegeben. Die asymptotische Gütegarantie beträgt 2, die Laufzeit &amp;lt;math&amp;gt;\mathcal O(n)&amp;lt;/math&amp;gt;. Der Vorteil dieses naiven Algorithmus ist, dass immer nur ein Behälter gleichzeitig geöffnet ist (was in der praktischen Anwendung eine Bedingung sein kann).&lt;br /&gt;
&lt;br /&gt;
== Literatur ==&lt;br /&gt;
* Bernhard Korte, Jens Vygen: &amp;#039;&amp;#039;Kombinatorische Optimierung.&amp;#039;&amp;#039; Springer, Berlin Heidelberg 2008, ISBN 978-3-540-76918-7, S. 485ff&lt;br /&gt;
&lt;br /&gt;
== Weblinks ==&lt;br /&gt;
* [https://pdfs.semanticscholar.org/bb99/86af2f26f7726fcef1bc684eac8239c9b853.pdf?_ga=1.50320358.1394974689.1485463187 Optimizing Three-Dimensional Bin Packing]&lt;br /&gt;
* [https://algo.rwth-aachen.de/~algorithmus/algo24.php Artikel im &amp;#039;&amp;#039;Algorithmus der Woche&amp;#039;&amp;#039;]&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
{{SORTIERUNG:Behalterproblem}}&lt;br /&gt;
[[Kategorie:Kombinatorische Optimierung]]&lt;br /&gt;
[[Kategorie:Komplexitätstheorie]]&lt;/div&gt;</summary>
		<author><name>90.187.14.241</name></author>
	</entry>
</feed>