if(Bedingung)

El Hadji

Bekanntes Mitglied
Servus Community;
Ich habe ien kleines Problem mit einer if-Bedingungen. Und zwar habe ich folgende Methode:

Transportgut[] waehleMaxAnzahl(Transportgut[] transportliste, double maxGewicht),

die aus der transportliste möglichst viele Transportgüter zum Transport auswählt, ohne dass das Gewicht der ausgewählten Transportgüter das maxGewicht übersteigt.

Und jetzt frage ich mich wie ich so eine Bedingung schrieben soll, oder bruache ich dazu noch ein paar Operatoren.

Ich wäre euch sehr dankbar, wenn ihr mir ein Stückchen weiterhelfen könntet.
mfg El Hadji
 

njans

Top Contributor
Na ja, du musst schon da eine Bedingung haben sowas wie:
Java:
if(transportliste[i].getWeight() <= maxGewicht)
 

El Hadji

Bekanntes Mitglied
Schon, aber wenn ich die Methode schreibe wie du meinst. Kontrolliert java ja nur den Gewicht. Ich könnte natürlich auch noch die Gewichter die kleiner sind als das max-Gewicht zusammenzählen und dann vergleichen. Aber ich weiß nicht wie ich es schaffe es in die if-Bedingung einzubauen dass möglichst viele Gewichte genommen werden. Denn sonst würde ja auch bei einer Liste {2,8,3,5}
Schon 2 und 8 stimmen, aber ich möchte 2,3,5
 

njans

Top Contributor
Du machst eine Collection (ArrayList, HashSet, etc) auf und läufst mit einer for-Schleife über alle Elemente in deinem Transportgut[]. Wenn diese die Bedingung erfüllen, dann fügst du sie zu deiner Collection hinzu.
 

njans

Top Contributor
Nein, das wird wohl kein Rucksackproblem sein :)
Denn du hast hier keine 2 Eigenschaften (Gewicht und Größe). Allerdings verstehe ich nun auch, was du meinst.
Was mir dazu einfällt: Sortiere das Array an Transportgütern nach dem Gewicht und dann läufst du da durch, beginnend mit dem leichtesten und nimmst so lange dadurch, bis das Hinzufügen des nächsten Gutes das Limit überschreitet.
Mal ein Beispiel der Gewichte:
Ungeordnet 1,54,156,47,9,2,45,6
Geordnet: 1,2,6,9,45,47,54,156
Und nun von links nach rechts hinzufügen, solange die Summe <= maxGewicht ist :)
 

stikio

Mitglied
Nein, das wird wohl kein Rucksackproblem sein
Denn du hast hier keine 2 Eigenschaften (Gewicht und Größe). Allerdings verstehe ich nun auch, was du meinst.
Was mir dazu einfällt: Sortiere das Array an Transportgütern nach dem Gewicht und dann läufst du da durch, beginnend mit dem leichtesten und nimmst so lange dadurch, bis das Hinzufügen des nächsten Gutes das Limit überschreitet.
Mal ein Beispiel der Gewichte:
Ungeordnet 1,54,156,47,9,2,45,6
Geordnet: 1,2,6,9,45,47,54,156
Und nun von links nach rechts hinzufügen, solange die Summe <= maxGewicht ist

das ist aber nicht die lösung ^^ und es ist doch eine variante des Rucksackproblems !

nehmen wir an du hast elemente mit kg: 1, 5, 6, 8, 12; Maximalgewicht = 15kg

jetzt nimmst du nach deiner methode 1+5+6 = 12 < 15 und 8 passt nicht mehr rein.
aber effektiver wäre dann doch 1+6+8 = 15

denn die ursprüngliche frage hat sich ja danach angehört als ob hier das optimum gefragt ist :)
 

njans

Top Contributor
"möglichst viele Transportgüter zum Transport auswählt, ohne dass das Gewicht der ausgewählten Transportgüter das maxGewicht übersteigt."
Klingt für mich überhaupt nicht nach einem Optimum. Das muss dann wohl mal der TO beantworten, ist ja schließlich seine Aufgabe ;)
 

El Hadji

Bekanntes Mitglied
Danke das es nach dem sortieren funktioniert habe ich verstanden. Aber wie erstelle ich ein Array ohne vorher definitv Werte festgelegt zu haben?
 

langhaar!

Bekanntes Mitglied
Wenn die Werte erst noch ermittelt werden müssen oder dynamisch hinzugefügt werden, dann nimm eine Liste. (zum Sortieren ohnehin besser)
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
T if-else Bedingung wird ignoriert Java Basics - Anfänger-Themen 4
B Alle Strings bis zu einer Maimallänge aufzählen, die Bedingung erfüllen Java Basics - Anfänger-Themen 13
Lion.King if-Bedingung Java Basics - Anfänger-Themen 3
B Zuweisungen und Methodenaufrufe in Bedingung der while Schleife? Java Basics - Anfänger-Themen 2
Avalon Warum funktioniert eine Bedingung und eine andere nicht? Java Basics - Anfänger-Themen 2
L while Schleife mit 2 Bedingung endet nicht Java Basics - Anfänger-Themen 3
M Wie lassen sich Konstanten in Bedingung stellen? Java Basics - Anfänger-Themen 1
M Wie lassen sich Objektkonstanten initialisieren, wenn sie eine Bedingung erreichen? Java Basics - Anfänger-Themen 6
M Wie verknüpfe ich eine Bedingung mit einer Methode ohne if-Verzweigung & Bedingungsoperator? Java Basics - Anfänger-Themen 2
A Dividieren mit Bedingung? Java Basics - Anfänger-Themen 7
P Bedingung in Schleife wird nicht ausgeführt Java Basics - Anfänger-Themen 5
Dimax Collections groupingBy mit Bedingung Java Basics - Anfänger-Themen 11
H Frage zur if-Bedingung bzw switch case Java Basics - Anfänger-Themen 6
F Bedingung für Eingabe Java Basics - Anfänger-Themen 2
scratchy1 Variablen vertauschen wenn Bedingung "umgedreht" wird Java Basics - Anfänger-Themen 40
Hanschyo If Bedingung Fehler Java Basics - Anfänger-Themen 7
T Komischer Fehler mit einer if-Bedingung Java Basics - Anfänger-Themen 3
W while Schleife und Bedingung Java Basics - Anfänger-Themen 11
E if-Bedingung mit mehreren Möglichkeiten ? Java Basics - Anfänger-Themen 6
S DefaultTableCellRenderer mit Bedingung Java Basics - Anfänger-Themen 1
J Fehler abfangen mit einer Bedingung Java Basics - Anfänger-Themen 3
Z Verschachtelte If-Bedingung Java Basics - Anfänger-Themen 6
N Methode mit While-Schleife und If-Bedingung und Array-Initialisierung Java Basics - Anfänger-Themen 4
L (Integer) Liste nach aufsteigender Summe der Ziffern sortieren (mit Bedingung) Java Basics - Anfänger-Themen 8
I Welche Schleife/Bedingung nehme ich her Java Basics - Anfänger-Themen 5
C Compiler-Fehler Wird eine if Bedingung nach einer for-Schleife nach jeder Iteration überprüft? Java Basics - Anfänger-Themen 1
B Kann mir jemand diese Bedingung erklären Java Basics - Anfänger-Themen 5
L Methoden if Bedingung trotz Erfüllung, nicht angesprochen Java Basics - Anfänger-Themen 12
P Compiler-Fehler if Bedingung fehlerhaft Java Basics - Anfänger-Themen 7
X Schleife bis "Bedingung" ausführen Java Basics - Anfänger-Themen 13
TheMenox Verschachtelte If Bedingung Java Basics - Anfänger-Themen 4
M Erste Schritte if-Bedingung schlägt fehl Java Basics - Anfänger-Themen 4
T Eigene Bedingung in IF-Bedingung Java Basics - Anfänger-Themen 22
Ocram Variablen Vereinfachung einer Bedingung Java Basics - Anfänger-Themen 18
J Can't find symbol - Erstellung eines Objekts in if-Bedingung Java Basics - Anfänger-Themen 3
M Frage zu if-Bedingung Java Basics - Anfänger-Themen 1
F Erste Schritte If Bedingung in Schleife dynamisch erweitern Java Basics - Anfänger-Themen 4
J Wo liegt nur an dieser einfachen Bedingung mein Fehler? Java Basics - Anfänger-Themen 8
R for-Schleife bei erfüllter Bedingung beenden Java Basics - Anfänger-Themen 7
R if funktion ohne else - Bedingung trifft nicht zu, ausgabe nicht nachvollziehbar Java Basics - Anfänger-Themen 7
S if bedingung - Stunde und Minute vergleichen Java Basics - Anfänger-Themen 5
K If-Bedingung mit Wertzuweisung Java Basics - Anfänger-Themen 2
J Vererbung If-Bedingung im Konstruktor Java Basics - Anfänger-Themen 15
J Arrays prüfen und über if Bedingung ausgeben Java Basics - Anfänger-Themen 15
T if Bedingung Java Basics - Anfänger-Themen 16
MiMa for Schleife Bedingung Java Basics - Anfänger-Themen 4
M in jTable schreiben unter Bedingung Java Basics - Anfänger-Themen 3
J Erste Schritte Kurze Frage zu Listenern und If-Bedingung Java Basics - Anfänger-Themen 2
N Verifikation einer if-Bedingung Java Basics - Anfänger-Themen 9
P Variablen ArrayList mit Bedingung iterieren Java Basics - Anfänger-Themen 2
L Erste Schritte Sollte ich hier lieber Cases verwenden oder wäre eine If-Bedingung besser? Java Basics - Anfänger-Themen 6
Anfänger2011 Wie bricht man alles ab wenn eine Bedingung nicht erfüllt ist? Java Basics - Anfänger-Themen 21
P Variablen Variable in if Bedingung anlegen, Wert zuweisen und diesen als Bedingung nutzen Java Basics - Anfänger-Themen 4
M Und Bedingung Java Basics - Anfänger-Themen 17
N Bedingung für Datentypen Java Basics - Anfänger-Themen 3
E if-Bedingung funktioniert nicht Java Basics - Anfänger-Themen 9
W Funktionsaufruf nach Bedingung Java Basics - Anfänger-Themen 3
S for schleife mit if bedingung Java Basics - Anfänger-Themen 21
S return(Bedingung) ? [mehrere Befehle] Java Basics - Anfänger-Themen 5
2 Bedingung bei Schleife Java Basics - Anfänger-Themen 23
E Methode in der Bedingung Java Basics - Anfänger-Themen 11
E if Bedingung Java Basics - Anfänger-Themen 4
H Sortierung eines String[][] mit Bedingung Java Basics - Anfänger-Themen 7
H Bedingung while-Schleife | integer number too large Java Basics - Anfänger-Themen 2
J Gibt es eine möglichkeit ähnlich wie .equals(bedingung1 ||bedingung ..n) ? Java Basics - Anfänger-Themen 5
I Potenzmenge mit Bedingung Java Basics - Anfänger-Themen 24
S If-Bedingung Java Basics - Anfänger-Themen 15
P Einfache Bedingung (?) in Java Java Basics - Anfänger-Themen 3
K Fragen zu If-Bedingung Java Basics - Anfänger-Themen 3
S bedingung in variable speichern? Java Basics - Anfänger-Themen 8
neurox Ergebnis der if-Bedingung weiter verwenden Java Basics - Anfänger-Themen 5
G If-Schleife läuft ohne erfüllte Bedingung Java Basics - Anfänger-Themen 13
K Logik in if-Bedingung Java Basics - Anfänger-Themen 2
S if anweisung wird ausgeführt egal ob bedingung true o. false Java Basics - Anfänger-Themen 2
S For Schleife, Bedingung Java Basics - Anfänger-Themen 4
S Wildcard-Bedingung Java Basics - Anfänger-Themen 10
G Probleme mit break hier; in if-Bedingung Java Basics - Anfänger-Themen 5
M Schleife abhängig von Bedingung Java Basics - Anfänger-Themen 5
G while Bedingung? Java Basics - Anfänger-Themen 6
L Bedingung immer false, auch wenn zwei Strings gleich sind Java Basics - Anfänger-Themen 11
L IF Bedingung in SELECT Statement? Java Basics - Anfänger-Themen 3
M Kleine Frage zu If-Bedingung Java Basics - Anfänger-Themen 4
Bierhumpen String Bedingung. Java Basics - Anfänger-Themen 8
M Comparable - Bedingung erzwingen Java Basics - Anfänger-Themen 3
R Klassen nach Bedingung laden Java Basics - Anfänger-Themen 22
G Compiler sieht die Bedingung nicht! Java Basics - Anfänger-Themen 5
W if Bedingung mit "Außer" Java Basics - Anfänger-Themen 4

Ähnliche Java Themen

Neue Themen


Oben