Alle Kombinationen aus ArrayList - Potenzmenge

swerm

Mitglied
Hi zusammen, bin seit längerem am suchen und langsam aber sicher am verzweifeln. Die Problemstellung ist eigentlich relativ einfach, allerdings macht mir die Umsetzung in Codeform sehr grosse Probleme. Es geht um das Rucksackproblem, daher habe ich eine gewisse Anzahl Objekte mit einer id, einem Wert und einem Gewicht erstellt. Nun möchte ich von allen möglichen Kombinationen das Gesamtgewicht und den Gesamtwert wissen.

z.B. habe ich 3 Objekte, {1, 2, 3}. Alle Möglichkeiten wären also {(1), (2), (3), (1,2), (1,3)... usw.}
Nun habe ich keine Ahnung wie ich alle diese Möglichkeiten "erzeuge". Die Objekte sind in einer ArrayList gespeichert. Wäre sehr froh wenn jemand helfen könnte! Hier Mal der bisherige Code:

Java:
//------------Code der Klasse Rucksack-------------------//
import java.util.ArrayList;
import java.math.*;

//Deklaration der Variabeln
public class Rucksack {
	private ArrayList<Objekt> objekte = new ArrayList<Objekt>();
	private ArrayList<Objekt> objekteInRucksack = new ArrayList<Objekt>();
	private int platz;
	private int gesamtwert;
	private int gesamtgewicht;
	private int bestwert;
	
//Konstruktor - Variabeln werden initialisiert
	public Rucksack(int platz){
		this.platz = platz;
		gesamtwert = 0;
		gesamtgewicht = 0;
	}
	
	//Objekte mit zufälligem Gewicht werden erzeugt
	public void erzeugeObjekte(){
		int i=0;
		int hoechstwert = 100;
		int hoechstgewicht = 100;
		int wert = 0;
		int gewicht = 0;
		
		for (i=0; i<50; i++){
			wert = (int) (Math.random()*hoechstwert+1);
			gewicht = (int) (Math.random()*hoechstgewicht+1);
			objekte.add(new Objekt(i, wert, gewicht));
		}
	}
	
	//Alle Objekte werden ausgegeben
	public void printAll(){
		for(Objekt obj : objekte){
			obj.print();
		}
	}
	
	//Alle Objekte die sich im Rucksack befinden werden ausgegeben
	public void printInRucksack(){
		for(Objekt obj : objekte){
			if(obj.getInRucksack() == 1){
				obj.print();
			}
		}
	}	
}


//------------------Code der Klasse Objekt----------------------------------

public class Objekt {
	int id;
	int wert;
	int gewicht;
	double verhaeltnis;
	int inRucksack;
	
	public Objekt(int id, int wert, int gewicht){
		this.wert = wert;
		this.gewicht = gewicht;
		verhaeltnis = wert / gewicht;
		inRucksack = 0;
		this.id = id;
	}
	
	public int getWert(){
		return wert;
	}
	
	public int getGewicht(){
		return gewicht;
	}
	
	public double getVerhaeltnis(){
		return verhaeltnis;
	}
	
	public void setInRucksack(int inRucksack){
		this.inRucksack = inRucksack;
	}
	
	public int getInRucksack(){
		return inRucksack;
	}
	
	public void print(){
		System.out.println("Objekt " + id);
		System.out.println("Gewicht: " + gewicht);
		System.out.println("Wert: " + wert);
		System.out.println("In Rucksack: " + inRucksack + "\n");
	}
}

Vielen Dank schon im Voraus für eure Hilfe! :)
 

Fab1

Top Contributor
Hallo,

ich habe hier mal etwas Pseudocode, da ich es momentan nicht testen kann.

Dein Problem ist anscheinend, dass du nicht weißt wie du die Kombination erstellst? Versteh ich das richtig?

Ansich würde das mit 2 geschachtelten Schleifen gehen.

Nehmen wir mal an du hast die Zahlen 1,2,3,4,5

Am Anfang erstmal alle ausgeben, somit hast du schonmal die einzelnen Objekte.

Jetzt brauchst du natürlich noch die Kombinationen.

Diese wären folgende:

(1,2)(1,3)(1,4)(1,5)
(2,3)(2,4)(2,5)
(3,4)(3,5)
(4,5)

Man sieht schon, die Anzahl der Kombinationen nimmt stetig um eine ab.


Rein logisch ist es ja so: Du vergleichst das erste Objekt/Zahl mit jedem anderen, dass größer ist wie Sie selbst. Also 2,3,4,5

Bei dem zweiten Objekt/Zahl wieder genauso. Also 3,4,5

und so weiter.

Hier sieht man schon, dass die Lösung eine geschachtelte Schleife ist. Hier muss ich leider sagen, ich kann mich recht schlecht in solch geschachtelte Schleifen "eindenken" muss lieber alles sehen, was momentan aber nicht möglich ist.

Mein Pseudocode:

Java:
// Ich mach jetzt mal nur mit den Zahlen und nem Array mit Objekten ist es ja ähnlich.
String kombi = "";
int [] array = {1,2,3,4,5}

for(int i = 0; i<array.length(); i++){

      for(int x = 0; x<array.length(); x++){
          kombi = kombi + array[i] + ";" + array[x] // ob das so stimmt, ka :-)
      } 

   }
for(int r : array){
System.out.print(r + " ");
}

System.out.println(\n +kombi);

Wenn ich daheim bin, würde ich es testen. Wenn bis dahin keine bessere Lösung vorhanden ist.

Greez
 

swerm

Mitglied
Hi, danke für die Antwort! :)
Diesen Ansatz habe ich auch schon durgedacht, allerdings sind in deinem Codebeispiel jeweils nur 2er Paare, ich brauche allerdings auch die 3er Paare, respektive bei n Einträgen im Array die "n"er Paare. D.h. ich müsste soviele ineinander geschachtelte For-Schleifen machen wie es Einträge im Array hat, was allerdings bei vielen Einträgen wenig sinnvoll ist, zumal das ganze noch variabel sein sollte.

Habe evt. Eine Lösung gefunden, die auf dem Binärsystem beruht, muss das ganze allerdings noch austesten. Falls es klappen sollte wird es natürlich geposted ;)
 

swerm

Mitglied
Hi, sorry habe deinen Post doch glatt übersehen. Werde mir das Mal anschauen, wenn ich das nur kurz überfliege kapier ich noch ziemlich wenig von dem was in der Klasse geschieht. Aber vielen dank, ist wohl genau das was ich gesucht habe! :)
 

Landei

Top Contributor
Das hier sollte alle Unter-Listen zurückgeben (ungetestet):

Java:
List<Integer> list = Arrays.asList(1,2,3,4);
for(int i = 0; i < 1 << list.size(); i++) {
    List<Integer> subList = new ArrayList<Integer>();
    for(int k = 0; k < list.size(); k++) {
        if ((i & (1 << k)) > 0) subList.add(list.get(k));
    }
    //tu was mit subList;
}
 
Zuletzt bearbeitet:
Ähnliche Java Themen
  Titel Forum Antworten Datum
Spot84 alle kombinationen einer string arraylist Allgemeine Java-Themen 2
_user_q Alle Kombinationen von "0000" bis "FFFF" kompakt schrieben Allgemeine Java-Themen 13
MaxG. Best Practice Alle Kombinationen berechnen Allgemeine Java-Themen 3
T Alle Kombinationen aus zwei Arrays Allgemeine Java-Themen 8
F Java Spintax: Alle Kombinationen Erzeugen Allgemeine Java-Themen 2
P Methoden Alle Kombinationen aus 2 Karten berechnen Allgemeine Java-Themen 2
G Alle Möglichen Kombinationen einer Liste Allgemeine Java-Themen 11
M Alle möglichen Kombinationen von mehreren Objekten berechnen Allgemeine Java-Themen 6
Zrebna Wie ermittelt man alle testbaren (zu testenden) Klassen in seinem Maven-Projekt? Allgemeine Java-Themen 23
_user_q JavaFX Robot alle Unicode-Zeichen schreiben lassen können Allgemeine Java-Themen 12
S Bookmark HTML Datei einlesen, alle Links erhalten und manche editieren..? (aktuell JSoup) Allgemeine Java-Themen 4
Sachinbhatt Sind alle Methoden in Java implizit virtuell Allgemeine Java-Themen 2
Kingamadeus2000 Alle mehrfach vorkommenden Buchstaben rekursiv aus einem String entfernen. Allgemeine Java-Themen 6
Drachenbauer wie kann ich alle instanzen einer Klasse durchsehen, ohne, dass diese in einer Liste erzeugt wurden? Allgemeine Java-Themen 11
8u3631984 Generelle Log4j.xml für alle Module Allgemeine Java-Themen 5
L Farbverlauf RGB alle Farben Allgemeine Java-Themen 28
W Server-Thread schreibt nicht alle Dateien Allgemeine Java-Themen 6
S Alle Dateinamen ermitteln Allgemeine Java-Themen 22
F Wie bekommt man alle Filenamen eines Webserver Verzeichnisses Allgemeine Java-Themen 6
S Kann ich eine Methode schreiben die alle Arten von funktionalen Interfaces akzeptiert..? Allgemeine Java-Themen 21
L Operatoren Java Reflections: Alle Methoden einer Klasse aufrufen ohne Exceptions Allgemeine Java-Themen 5
J Best Practice Objekt an alle Klassen verteilen ( Discord Bot ) Allgemeine Java-Themen 7
C BufferedReader/BufferedWriter schreibt nicht alle Bytes Allgemeine Java-Themen 2
J Alle Unit Tests in Maven Modul Projekt ausführen Allgemeine Java-Themen 7
S Anwendung die alle Abhaengigkeiten einer Library listet..? Allgemeine Java-Themen 5
K Nicht alle class-Dateien im JRE? Allgemeine Java-Themen 2
I Alle logs von Logger bekommen Allgemeine Java-Themen 3
U javax.mail.Folder.list() zeigt nicht alle Ordner Allgemeine Java-Themen 5
K Classpath Alle Classen aus einem Package lesen Allgemeine Java-Themen 7
L Alle möglichen Additionen (Rekursiv) Allgemeine Java-Themen 3
KaffeeFan Methoden replace alle Buchstaben Allgemeine Java-Themen 3
S Alle Methodenaufrufe eines Threads notieren..? Allgemeine Java-Themen 7
U Koordinaten alle Pixel eines Dreiecks zeichnen ausgeben Allgemeine Java-Themen 5
Z Eclipse hängt sich alle paar Sekunden auf (Keine Rückmeldung). Allgemeine Java-Themen 4
Seikuassi Alle Escape-Sequenzen in einem String ersetzen Allgemeine Java-Themen 4
Sogomn Klassen Alle in eine Klasse Allgemeine Java-Themen 11
B Threads Barrier mit wait()/notify() aber nicht alle Prozesse terminieren Allgemeine Java-Themen 2
S .jar hat nicht alle Klassen ??? Allgemeine Java-Themen 10
T Wie kann ich alle existierenden Java-Klassen anzeigen lassen? Allgemeine Java-Themen 10
M Zufälligen String generieren und alle 5 Minuten ändern Allgemeine Java-Themen 2
M RegEx alle Matches ausgeben Allgemeine Java-Themen 5
A Applet Alle Threads beim schließen des Applets beenden Allgemeine Java-Themen 8
C SwingWorker.cancle(true) tötet alle Worker Allgemeine Java-Themen 3
B Methoden Alle Methoden und Variablen aus Java-Dateien auslesen. Allgemeine Java-Themen 7
T Alle Instancen einer Klasse auflisten Allgemeine Java-Themen 13
S Programm das alle aufgerufenen Methoden ausgibt..? Allgemeine Java-Themen 6
D Alle Variablen final setzen ? Allgemeine Java-Themen 26
brunothg Alle Kombiationen von n Ziffern Allgemeine Java-Themen 2
M Erste Schritte alle xmlFiles in zugehörige pdfFiles einlesen Allgemeine Java-Themen 4
B Variablen Alle RenderingHints.Keys (KEY_*) in Array + alle RenderingHints.Keys (VALUE_*) in Object[] Allgemeine Java-Themen 8
D generische Klasse für alle Maps (nicht Collections :-)) Allgemeine Java-Themen 11
E Logger loggt nicht alle Level Allgemeine Java-Themen 2
S Aus einer Liste<Oberklasse> alle Elemente die eine bestimmte Unterklasse von Oberklasse haben filter Allgemeine Java-Themen 8
K String: alle X Zeichen Zeilenumbruch Allgemeine Java-Themen 3
F Alle Exceptions abfangen Allgemeine Java-Themen 4
nrg JS als ScriptEngine - alle Punkte ersetzen Allgemeine Java-Themen 4
A Bildschirmauflösung geändert - alle Bildschirminhalte verschoben - was tun? Allgemeine Java-Themen 7
C Alle Klassen eines Packages lesen und instanzieren? Allgemeine Java-Themen 9
B Alle Exceptions auf einmal abfangen Allgemeine Java-Themen 4
S Warum packt er nicht alle Dateien? Allgemeine Java-Themen 13
J Alle Tage eines Jahres Allgemeine Java-Themen 2
AlexSpritze Alle Domains oder FQDN von einem Server erfragen? Allgemeine Java-Themen 2
S Alle Elemente von zwei Listen vergleichen Allgemeine Java-Themen 10
J Konstrukt um alle Paare und Tripel einer Punkte-Menge bilden Allgemeine Java-Themen 12
B Alle möglichen Buchstabenkombinationen in einem String Allgemeine Java-Themen 7
P alle zusammanhaengenden teilgraphen Allgemeine Java-Themen 7
A alle nicht-dplikate finden Allgemeine Java-Themen 14
M Wie kann ich alle System.out Strings in ein log window umleiten? Allgemeine Java-Themen 6
E Alle unter Prozesse der beim schließen mit schließen Allgemeine Java-Themen 3
A An alle Cracks: Anwendung beenden mit ShutdownHook? Allgemeine Java-Themen 13
J Logger gibt nicht alle Level aus Allgemeine Java-Themen 3
M alle möglichen Zahlenkombinationen Allgemeine Java-Themen 5
B in welchem verzeichnis liegen alle installierten klassen? Allgemeine Java-Themen 6
hdi Für alle fleissigen Helfer! Allgemeine Java-Themen 15
N Alle Fehler ausgeben? Allgemeine Java-Themen 4
J Zweiter Prozess der alle x Sekunden etwas abfragen soll Allgemeine Java-Themen 2
O Auf alle Events reagieren Allgemeine Java-Themen 3
B J-Unit Tests. Alle Tests eines Package einsammen. Allgemeine Java-Themen 4
U alle Dateien eines Ordners innerhalb einer JAR auflisten Allgemeine Java-Themen 6
S toString() für alle Member einer Klasse. Allgemeine Java-Themen 6
G Alle möglichen Konfigurationen eines Baumes Allgemeine Java-Themen 4
C Alle Möglichen Substrings der Länge k aus String extrahieren Allgemeine Java-Themen 9
C Alle Bilder eines binären Arrays ausgeben Allgemeine Java-Themen 3
G Alle möglichen Permutationen einer Folge n Allgemeine Java-Themen 3
V Alle Klassen eines Package auflisten? Allgemeine Java-Themen 6
H JTable Löschen [Alle Zeilen aufeinmal Löschen] Allgemeine Java-Themen 6
@ RegEx: Alle Sonderzeichen ausser dem Punkt Allgemeine Java-Themen 4
H Alle möglichen Hochkommata ausschließen Allgemeine Java-Themen 6
M Gibt es ein Jar - das alle Componente Automatisch anpasst? Allgemeine Java-Themen 14
K Suche alle Objekte einer bestimmten Klasse Allgemeine Java-Themen 2
N Unter Mac Os X alle laufenden Prozesse ausgeben Allgemeine Java-Themen 3
S Änderung an Proberties datei an alle User weitergeben? Allgemeine Java-Themen 7
P Observer, nicht alle updates bearbeiten Allgemeine Java-Themen 2
der JoJo [TreeSelection] wie bekomme ich alle Elemente Allgemeine Java-Themen 4
G Alle Zeichen des Alphabets ausgeben Allgemeine Java-Themen 4
G Alle Möglichkeiten n Elemente Anzuordnen. Allgemeine Java-Themen 13
0 Alle Teiler einer Zahl performant berechnen? Allgemeine Java-Themen 9
J Funktion alle Möglichkeiten berücksichtigen Allgemeine Java-Themen 5
O Warten bis alle gestarteten Threads beendet sind? Allgemeine Java-Themen 6
G HTML file Alle relativen URL in absolute URL umschreiben? Allgemeine Java-Themen 12

Ähnliche Java Themen

Neue Themen


Oben