![]() |
|
|
|||||||
| Java Basics - Anfänger-Themen Fragen ausschließlich zu Java-Grundlagen von Ein- und Umsteigern |
|
|
|
Themen-Optionen | Thema durchsuchen | Ansicht |
| #1 (permalink) | |||
|
Neuer Benutzer
Bit
Registriert seit: 25.06.2012
Fachbeiträge: 4
Abgegebene Danke: 2
Erhielt 0 Danke für 0 Beiträge
|
Hallo,
ich möchte gern ein 2 dimensionales int array (4x4 Plätze) zufällig mit den zahlen von 1-8 füllen. Doch leider klappt das nicht so ganz, wie es mir vorstelle. Manchmal klappt es und manchmal nicht. Kurz die Erläuterung, wie ich mir das gedacht habe. Ich lass nacheinander die Zahlen von 1-8 eintragen. Um das zufällig geschehen zu lassen, lass ich die Zahl in einen zufällig ausgewählten Array-Platz schreiben. Sollte der Array-Platz bereits gefüllt sein, so soll ein neuer Platz gesucht werden und geprüft werden, ob der frei ist. Wenn er frei ist, dann soll die Zahl dort rein und wenn nicht, dann soll er einen neuen Platz suchen. Und das soll eben so lange laufen, bis die Zahlen von 1-8 in der Matrix stehen. Ich denke der Fehler liegt bei der do-while Schleife. Aber wo genau keine Ahnung. Wäre super, wenn einer von euch Profis, da mal drüberschauen könnte. So und hier kommt jetzt der Quellcode.
Vielen Dank schon mal für die Hilfe! |
||
|
|
|
| #2 (permalink) | |||
|
Stammbenutzer
Halbes Megabyte
Registriert seit: 04.04.2012
Fachbeiträge: 553
Abgegebene Danke: 23
Erhielt 79 Danke für 78 Beiträge
|
Im Prinzip funktioniert das schon, obwohl du es deutlich einfacher gestalten könntes.
Es ist aber Glücksache, wie lange es dauert. Im Schlimmsten Fall "trifft" er das letzte Feld einfach (sehr lange) nicht! Du beschreibst gar nicht, was dein Problem ist, bzw was passiert. (Ist immer schlecht im Forum!) Ein anderer Ansatz wäre: 8 Zahlen in ein Feld schreiben, mischeln ( Collections.shuffle )und dann der Reihe nach verteilen.
__________________
Eine System.out.println(...)-Zeile an passender Stelle:[*]... sagt dir die Lösung oft schneller als das Forum, [*]... erhöht den Nutzwert deines Gehirn, [*]... macht ein geiles Gefühl, weil du das Problem selbst löst.Disclaimer: Alle grammatikalischen Ausdrücke/innen gelten geschlechtsneutral in der männlichen und weiblichen Form/in. Geändert von AquaBall (25.06.2012 um 19:43 Uhr) |
||
|
|
|
| Danke sagt: |
-thesi (25.06.2012)
|
| #3 (permalink) | |
|
Stammbenutzer
Megabyte
Registriert seit: 01.06.2011
Fachbeiträge: 1.111
Abgegebene Danke: 5
Erhielt 218 Danke für 217 Beiträge
|
Warum nicht so ?
__________________
Vorwiegend hier um Anfängern Hilfestellung zu geben. ► DANKE Button nutzen, wenn Beiträge geholfen haben. ► JAVA-TAGs nutzen, damit Java Code auch richtig dargestellt wird. Sourcecode bei BitBucket: njans Geändert von njans (25.06.2012 um 20:02 Uhr) |
|
|
|
| Danke sagt: |
-thesi (25.06.2012)
|
| #4 (permalink) | |
|
Neuer Benutzer
Bit
Themenstarter
Registriert seit: 25.06.2012
Fachbeiträge: 4
Abgegebene Danke: 2
Erhielt 0 Danke für 0 Beiträge
|
Wow das ging ja fix mit den Antworten
Dafür schon mal danke. @AquaBall: Jein es ging ab und zu. Manchmal hat er einfach irgendwelche Zahlen nicht eingetragen, dann waren nur die Zahlen 1,2,3,4,6,8 oder 1,2,5,6,7,8 in der Matrix drin. Und wenn ich eben Glück hatte, dass er immer einen "leeren" Platz gefunden hat, dann war die Matrix vollständig. Und ja ich hab ganz vergessen das Problem wirklich zu benennen. War wohl einfach so, weil ich schon die ganze Zeit drübergesessen bin und schon so verzweifelt war und genau wusste worum es geht. Aber das könnt ihr ja nicht wissen. Entschuldige. Das nächste Mal werd ich es nicht vergessen ! @njans: Super der Code funktioniert einwandfrei und ist auch noch so viel kürzer als meiner. Ich versuche ihn mal zu verstehen und du/ihr korrigiert mich bitte, wenn ich was falsches sage. In Zeile 1 legen wir wieder die for Schleife an um zuerst die Zahl 1 in einen Platz zuschreiben und danach die Zahl 2 usw. Zeile 3 und 4 geben die zufällige Position aus. Zeile 6 prüft ob der Platz frei ist. Ist er frei, dann schreibt er die Zahl (beim ersten Durchlauf die 1, beim zweiten Durchlauf die 2 usw.) rein. Aber jetzt kommt das Problem, Zeile 9+10. Wenn der Platz nicht frei ist, dann verringern wir i. Führt das dazu, dass das i von der for-Schleife verringert wird? Als Beispiel: Er hat die Zahl 1 reingeschrieben und muss jetzt die 2 reinschreiben. Wenn er die Zahl 2 in den Platz reinschreiben will wo schon die Zahl 1 steht, wird i um 1 verrigert, also ist i wieder 1. Danach wird durch die for-Schleife i von 1 auf 2 erhöht und er sucht wieder einen leeren Platz. Wenn er wieder keinen findet, dann setzt er i wieder auf 1 und die for-Schleife setzt i wieder auf 2 und das Spielchen geht solange weiter, bis er einen freien Platz findet, oder? Hab ich das richtig erfasst? |
|
|
|
| #5 (permalink) | |||||||||||||||||||
|
Stammbenutzer
Megabyte
Registriert seit: 01.06.2011
Fachbeiträge: 1.111
Abgegebene Danke: 5
Erhielt 218 Danke für 217 Beiträge
|
In dem neuen Beispiel wird i nur erhöht, wenn auch ein Platz gefunden wurde, in den die Zahl geschrieben wurde.
__________________
Vorwiegend hier um Anfängern Hilfestellung zu geben. ► DANKE Button nutzen, wenn Beiträge geholfen haben. ► JAVA-TAGs nutzen, damit Java Code auch richtig dargestellt wird. Sourcecode bei BitBucket: njans |
||||||||||||||||||
|
|
|
||||||||||||||||||
| #6 (permalink) | |||||||||||||||||||
|
Neuer Benutzer
Bit
Themenstarter
Registriert seit: 25.06.2012
Fachbeiträge: 4
Abgegebene Danke: 2
Erhielt 0 Danke für 0 Beiträge
|
Ich wusste gar nicht, dass man die Inkrementierung von i auch in der Schleife machen kann. Ich dachte, dass man das oben in den runden Klammern von der for-Schleife machen muss. Super, da hab ich wieder was dazu gelernt. Vielen Dank! |
||||||||||||||||||
|
|
|
||||||||||||||||||
| #7 (permalink) | |||
|
Java-Forum Team
Moderator
Registriert seit: 06.01.2007
Fachbeiträge: 16.748
Abgegebene Danke: 0
Erhielt 1.640 Danke für 1.485 Beiträge
|
Auch da besteht die theoretische Möglichkeit, dass er unendlich lange läuft. Ein theoretischer Informatiker würde ganz klar sagen: "Der Algorithmus ist nicht total korrekt." (Auch wenn das, wenn man das so liest, klingt, als könnte man da noch ein "...Alda!
" erwarten )Das angesprochene "shuffle" war schon das richtige. Man kann es auch nachbauen, wenn man direkt auf arrays arbeiten will:
Dabei noch ein Hinweis: java.util.Random in der oben angedeuteten Form zu verwenden ist praktisch immer besser als Math.random. Bei Math.random kriegt man immer zufällige Zahlen, und das ist die Hölle beim debuggen. Mit Random random = new Random(0); bekommt man immer die gleiche (zufällige) Abfolge von Zahlen (und praktischerweise kann man sie mit "nextInt" gleich als ints abholen). Wenn es dann "ECHT zufällig" sein soll, nimmt man Random random = new Random(); // Ohne parameter |
||
|
|
|
| #8 (permalink) | |
|
Neuer Benutzer
Bit
Themenstarter
Registriert seit: 25.06.2012
Fachbeiträge: 4
Abgegebene Danke: 2
Erhielt 0 Danke für 0 Beiträge
|
Puh, also langsam werd ich wieder verwirrter, nachdem ich es eigentlich verstanden hatte.
Den Code von dir Marco13, schau ich mir morgen mal an. Mein Hirn braucht jetzt eine Verschnaufpause. Aber wirklich ein riesen Dankeschön an euch alle für die schnelle und variantenreiche Hilfe
|
|
|
|
|
| Themen-Optionen | Thema durchsuchen |
| Ansicht | |
Ähnliche Themen
|
||||
| Thema | Autor | Forum | Antworten | Letzter Beitrag |
| DirectBufferedImage | Marco13 | Codeschnipsel u. Projekte | 34 | 17.04.2012 18:39 |
| Objects speichern | wessi86 | Java Basics - Anfänger-Themen | 4 | 07.07.2011 01:11 |
| Unsatisfied Link Error | Stapf_JAVA | Java Basics - Anfänger-Themen | 5 | 04.05.2011 15:18 |
| Mehrere Steine gleichzeitig setzen und bewegen | SSJ | Spiele- und Multimedia-Programmierung | 4 | 19.04.2009 15:54 |
| TileBased Spiel schneckenlangsam | Steev | Spiele- und Multimedia-Programmierung | 13 | 05.12.2007 06:43 |
| Lesezeichen |
|
|