Zweidemensionales Array auf zwei gleiche Zahlen prüfen

Status
Nicht offen für weitere Antworten.

OiM86

Mitglied
Hallo liebe Forum Mitglieder (und natürlich auch Gäse )

Ich komm grad bei eine Aufgabe nicht weiter. Mir fehlt einfach grad eine Idee.
Ich hab ein zwei demensionales Array mit insgesamt 36 Feldern.

[Java]
static int[][] a = new int[6][6];
[/code]

Das Feld 0,5 und 5,0 ist mit einer 1 belegt:

Java:
a[0][5] = 1;
a[5][0] = 1;

Jetzt soll ich den Array mit 10 weiteren Einsen füllen (so das ich am ende 12 Einser hab). Dabei ist die Bedinnung dass in jeder Horinzontalen in jeder Vertikalen und Diagonalen nur ZWEI einser stehen.

Also das es zum Schluss z.B so aussieht:

1 0 0 0 0 1
0 0 1 1 0 0
0 1 0 0 1 0
0 1 0 0 1 0
0 0 1 1 0 0
1 0 0 0 0 1

Ich komm einfach nicht drauf wie ich die Schleifen bauen soll.
Für paar Tips wär ich sehr dankbar

Danke im vorraus !
 

Marco13

Top Contributor
Ganz einfach:
Java:
a[0][0] = 1;
a[1][2] = 1;
a[2][1] = 1;
... usw...

Wenn man davon ausgeht, dass das ein allgemeineres Problem ist, und die Aufgabe lautet "Für einen Array der größe n x n soll eine Verteilung gefunden werden, so dass in jeder Spalte/Zeile nur k Einsen stehen", muss man sich was überlegen. Das kann dann aber schon ziemlich untrivial werden...
 

OiM86

Mitglied
ja ne. Also es gib ja mehrer Lösungsmöglichkeiten ! Daher soll ich Prüfen ob die 1 an der gegeben Positon stehen kann, wenn ja dann 1 eintragen wenn nein dann nähste Position prüfen.

Und mir fehlt eben die Idee wie ich das Prüfen mach. Vor allem in der Diagonalen !
 

Dag B.

Aktives Mitglied
Hallo,

ich würde es mit 2 Zählern machen. Müssten glaube ich Zählerarrays sein. :rtfm:

Und deren Index dann über 2 ineinander verschachtelte for-Schleifen erhöhen.

Wenn beide Zähler an der Position kleiner als 2 sind kann er die 1 schreiben, sonst eben nicht.

Mal so als grobe Idee.
 

Marco13

Top Contributor
ja ne. Also es gib ja mehrer Lösungsmöglichkeiten ! Daher soll ich Prüfen ob die 1 an der gegeben Positon stehen kann, wenn ja dann 1 eintragen wenn nein dann nähste Position prüfen.
... und wenn man durch das Eintragen einer 1 an einer bestimmten Stelle eine Lösung unmöglich gemacht hat, aber eine Lösung möglich gewesen wäre, wenn man diese 1 an einer anderen Stelle eingetragen hätte, ist man beim Backtracking .... und darauf wollte ich hinaus...
 

Landei

Top Contributor
Ist nicht immer eine "Treppe" eine gültige Lösung?
Code:
000011
000110
001100
011000
110000
100001
 

Dag B.

Aktives Mitglied
Und mir fehlt eben die Idee wie ich das Prüfen mach. Vor allem in der Diagonalen !

Naja, für die Diagonalen (hatte ich ganz überlesen ^^ ) musst du dir halt auch irgendeine Regelmäßigkeit überlegen.

Dazu schau dir mal die Diagonalen an bzw deren Indizes. zB von unten rechts nach oben links:
0:0 -> 1:1 -> 2:2 -> 3:3 -> 4:4 -> 5:5
oder auch: 0:1 -> 1:2 -> 2:3 -> 3:4 -> 4:5
Fällt dir was auf, wie sich die Indizes verändern? :)

Und dann eben noch schauen, wies mit den Indizes der anderen möglichen Diagonalen aussieht. Wird natürlich ein ziemliches Abfragengewusel, aber was besseres fällt mir aktuell dazu nicht ein. ^^
 

Dag B.

Aktives Mitglied
Über Backtracking kriegste doch aber auch nicht die Belegung der Diagonalen ohne ihm zu sagen, "was" die Diagonalen sind.

Wenn das Programm nicht weiß, dass es auch 0:0 mit 1:1 vergleichen muss, kann es auch nicht prüfen ob der Weg zu einer Lösung führen würde.
Und mehr als das, habe ich ja nicht ausgeführt. ;)
Wie man sein Abfragengewusel und den Rest baut (backtracking, unendlich viele if-Schleifen etc. pp.) steht auf einem anderen Blatt geschrieben. ^^
 

Marco13

Top Contributor
Hmmmjjaaa... kommt drauf an, was das Ziel dieser Aufgabe(?) ist. Natürlich könnte man hinschreiben
Code:
if      (a[0][0]==1 && a[1][1]==0 && a[2][2]==0 && a[3][3]==0 && a[4][4]==0 && a[5][5]==0) a[1][1] = 1;
else if (a[0][0]==0 && a[1][1]==1 && a[2][2]==0 && a[3][3]==0 && a[4][4]==0 && a[5][5]==0) a[0][0] = 1;
else if (a[0][0]==0 && a[1][1]==0 && a[2][2]==1 && a[3][3]==0 && a[4][4]==0 && a[5][5]==0) a[0][0] = 1;
...
 //  Viel Spass damit...
Ich gehe aber davon aus, dass es fast unmöglich ist, dieses Abfragemonster so systematisch und konsistent hinzuschreiben, dass es wirklich funktioniert....

Wenn man statt eines Programmes, das das Problem für
- ein 6x6-Array
- mit 2 vorgegebenen 1en
- mit der Bedingung: Max. 2 einsen senkrecht, waagerecht, diagonal
löst, und dafür 1000 unwartbare, unverstehbare, und (vermutlich) unmöglich "richtig" hinzuschreibende Zeilen wie die open angedeuteten verwendet, EINmal ein kleines Backtracking implementiert (was für so ein Problem reichlich trivial ist) und dafür nur 100 Zeilen benötigt, von denen eine eben die Zeile
Code:
boolean isValid = currentConfigurationIsValid();
ist, ist das sicher sinnvoller.

Stell dir vor, das Programm ist fertig, und dann ist der Lehrer fies und sagt: "Sooo, das ganze jetzt auf einem 7x7-Array", oder "Jetzt darf in den Diagonalen nur noch jeweils EINE 1 stehen". Wenn man das Problem "speziell" gelöst hat, ist man dann ... "gefickt", wie der Lateiner sagt. Im anderen Fall würde man in der "currentConfigurationIsValid"-Methode aus einer 2 eine 1 machen, und wäre fertig.

Ohne jetzt einen Flamewar zwischen den Verfechtern von You Are Gonna Need It und You Arent Gonna Need It anzetteln zu wollen: So eine Aufgabe stellt man nicht, weil sie speziell gelöst werden soll (sonst kann man das so machen wie ich in meiner ersten Antwort angedeutet hatte), sondern vermutlich eher, weil man einen Algorithmus zur allgemeinen Lösung finden und implementieren soll....
 

Dag B.

Aktives Mitglied
Hmmmjjaaa... kommt drauf an, was das Ziel dieser Aufgabe(?) ist. Natürlich könnte man hinschreiben
Code:
if      (a[0][0]==1 && a[1][1]==0 && a[2][2]==0 && a[3][3]==0 && a[4][4]==0 && a[5][5]==0) a[1][1] = 1;
else if (a[0][0]==0 && a[1][1]==1 && a[2][2]==0 && a[3][3]==0 && a[4][4]==0 && a[5][5]==0) a[0][0] = 1;
else if (a[0][0]==0 && a[1][1]==0 && a[2][2]==1 && a[3][3]==0 && a[4][4]==0 && a[5][5]==0) a[0][0] = 1;
...
 //  Viel Spass damit...
Du musst doch nur (rekursiv?) abfragen, ob zB bei der Diagonalen von rechts oben nach links unten alle Vorgänger (-1:-1) und nachfolger (+1:+1) mit 1 belegt sind. Das meinte ich mit der Regelmäßigkeit.

Also irgendwie
Java:
if(Feld[index1 + i][index2 + i] == 0)
    //Erneuter aufruf mit i + j erhöht/erniedrigt.
Damit wäre deine Monsterabfrage schonmal kleiner.

Und dort dann unter den erneuten aufruf vllt einen Zähler, welcher im else um 1 erhöht wird. Beträgt der 2, darf man nichts schreiben.

Also irgendwie so, in Pseudocode (fehlt noch bissel was, aber zur Illustration) :
Java:
count := 0;
while(count kleiner 2)
   for(i := 1; i < 6; i++)
         if(Feld[index1 + i][index2 + i] gleich 1)
            Erhöhe count um 1
         end if
   end for
end while
if(count kleiner 2)
   Schreibe 1 an Stelle Feld[i][j]
Wird immer noch ein ziemlicher Wust, weil man ja Feld[i-1][j-1] auch checken muss und zusätzlich die Prüfung fehlt, ob i+1 und j+1 überhaupt noch kleiner als die Arraylänge sind.
Und dann hat man nur eine einzige Diagonale. ^^"
Aber es war ja auch nur eine grobe Idee, ich wollts nur nochmal ausführen, weil ich mit keinem Wort gesagt habe der soll den Schmarn einzeln prüfen. :shock:

Schließlich wollte ich anregen, nicht die Aufgabe komplett für OiM86 lösen. :p
 
A

Apokalypse

Gast
Hallo ich habe gerade interesiert diesen Thread gelesen.
Vielleicht schaust, du dir mal das Damenproblem an.
Das geht in die gleiche Richtung wie dein Problem

Gruß Apo
 

Marco13

Top Contributor
Also irgendwie so, in Pseudocode (fehlt noch bissel was, aber zur Illustration) :
Java:
count := 0;
while(count kleiner 2)
   for(i := 1; i < 6; i++)
         if(Feld[index1 + i][index2 + i] gleich 1)
            Erhöhe count um 1
         end if
   end for
end while
if(count kleiner 2)
   Schreibe 1 an Stelle Feld[i][j]
Ja, und dann halt...
Code:
if (irgendwann wurde an Position (i,j) gesetzt und jetzt gibt es keine Lösung)
{ 
    Mache alles rückgängig was seit dem Setzen bei (i,j) gemacht wurde
    Schreibe 1 an eine andere Stelle als (i,j)
    Schau' nach ob es jetzt eine Lösung gibt........
}
Apokalypse hat schon recht. Das Damenproblem kann man genau so wie dieses Problem lösen (also mit demselben Quellcode!) - nur die Methode "currentConfigurationIsValid" muss etwas anders implementiert werden.
 

Dag B.

Aktives Mitglied
Ich weiß, sowohl das Dame- als auch das Springerproblem musste ich schon selbst lösen.
Ist aber schon ewig her. ^^

Meins war wie gesagt kein kompletter Lösungsansatz sondern nur ein Hinweis, wie man die Zeilen, Spalten und Diagonalen prüfen >könnte<.
 

OiM86

Mitglied
Vielen Dank für euren zahlreichen Antworten ! Dank Dag B. bin ich auf die Lösung gekommen.
 
Zuletzt bearbeitet:
Status
Nicht offen für weitere Antworten.
Ähnliche Java Themen
  Titel Forum Antworten Datum
T Array verkleinern Java Basics - Anfänger-Themen 2
J Array aus Numberfield Eingaben Java Basics - Anfänger-Themen 7
D Array List mit Objekten sortieren Java Basics - Anfänger-Themen 2
onlyxlia Anzahl Random Zahlen mit Scanner abfragen und in Array speichern Java Basics - Anfänger-Themen 10
Ü Java Array - Buchstaben als Zahlen ausgeben Java Basics - Anfänger-Themen 22
Ü Zweidimensionales Array in der ersten Zeile deklarieren Java Basics - Anfänger-Themen 13
Thomas Uppe 2D Array Reihenfolge vermischen Java Basics - Anfänger-Themen 4
T array auslesen Java Basics - Anfänger-Themen 2
Nitrogames Variablen Variable aus JOptionPane Abfrage in Array einfügen Java Basics - Anfänger-Themen 4
moini Auf Array aus Superklasse zugreifen? Java Basics - Anfänger-Themen 2
J ArrayList in 2D-Array konvertieren. Java Basics - Anfänger-Themen 48
M NullPointerException: Cannot read the array length because "this.Kinder" is null Java Basics - Anfänger-Themen 1
P Wieso kann ich als Index für einen Array einen Char angeben? Java Basics - Anfänger-Themen 3
Finn_lol Fehlermeldung bei Schleife mit Array Java Basics - Anfänger-Themen 4
Proxy Chars vor array übergabe toLowerUpcase Java Basics - Anfänger-Themen 14
iAmFaiinez Primzahlen Tester ohne Array Java Basics - Anfänger-Themen 4
S array 2 dimensional treppe Java Basics - Anfänger-Themen 3
S Array 2x2 Blöcke mit 0 und 1 Java Basics - Anfänger-Themen 10
C Array von Klassen Java Basics - Anfänger-Themen 2
julian0507 2Dim-Array Spaltensummen Java Basics - Anfänger-Themen 1
XWing Doppelte Zahlen im Array Java Basics - Anfänger-Themen 8
melisax Java 2D-Array Tabelle Java Basics - Anfänger-Themen 4
melisax Java Array Wert an bestimmtem Index angeben Java Basics - Anfänger-Themen 14
W Items löschen aus String Array vom Custom Base Adapter Java Basics - Anfänger-Themen 2
Proxy Stack erweitern mit neuem Array falls der alte voll ist!? Java Basics - Anfänger-Themen 5
E Array, nächste Zahl zur 5 ausgeben, wie? Java Basics - Anfänger-Themen 42
J Array.list vergleichen Java Basics - Anfänger-Themen 1
W Java-Code mit Array Java Basics - Anfänger-Themen 14
D Reflections & Generisches Array Java Basics - Anfänger-Themen 4
T Array Java Basics - Anfänger-Themen 2
T Array Java Basics - Anfänger-Themen 15
T Wörteranzahl im Array zählen Java Basics - Anfänger-Themen 9
Ostkreuz Zweidimensionaler Array Index Java Basics - Anfänger-Themen 2
S String Array Buchstaben um einen gewissen Wert verschieben Java Basics - Anfänger-Themen 4
R Images aus einem Array ausgeben Java Basics - Anfänger-Themen 3
R 2d Array individuell machen Java Basics - Anfänger-Themen 4
D 2D Char Array into String Java Basics - Anfänger-Themen 2
J Array Median bestimmen Java Basics - Anfänger-Themen 6
S Array Maximum bestimmen mit for und foreach Java Basics - Anfänger-Themen 7
S Prüfen ob ein zweidimensionales Array rechteckig ist Java Basics - Anfänger-Themen 4
N Array Java Basics - Anfänger-Themen 1
J Array Mittleren Wert bestimmen Java Basics - Anfänger-Themen 2
D OOP Array einem Objekt zuweisen Java Basics - Anfänger-Themen 2
O Zahlen aus einem char-array per char + Zeichen addieren Java Basics - Anfänger-Themen 2
S leeres Array statt Null Pointer Exception ausgeben Java Basics - Anfänger-Themen 20
S Inhalte aus Array vergleichen und Max ausgeben Java Basics - Anfänger-Themen 3
M 2d array ohne längen anlegen Java Basics - Anfänger-Themen 4
S Bestimmte werte aus einem Array löschen Java Basics - Anfänger-Themen 2
S Ausgeben wie oft ein Wert in einem Array vorkommt Java Basics - Anfänger-Themen 7
E Reihenfolge der Werte umdrehen (mittels statischem int-Array Java Basics - Anfänger-Themen 3
O 2 Dimensionales Array Java Basics - Anfänger-Themen 6
M Bubble Sort - Int[] Array sortieren Java Basics - Anfänger-Themen 2
javaBoon86 Array mehrere Dimensionen Java Basics - Anfänger-Themen 10
B Array nach Elementwerten sortieren? Java Basics - Anfänger-Themen 1
B Explizit Array definieren geht nicht? Java Basics - Anfänger-Themen 14
D Kleinste Zahl in Array finden die vorher noch errechnet werden müssen. Java Basics - Anfänger-Themen 4
L Gegebenes Array sortieren, indem zufällige Zahlenpaare aus Array ausgewählt werden Java Basics - Anfänger-Themen 14
Say 2-DIM Array Code lesen und verstehen Java Basics - Anfänger-Themen 5
N Array beim erstellen mit Werten füllen Java Basics - Anfänger-Themen 6
C Java Array Struktur, welche ist wann besser? Java Basics - Anfänger-Themen 12
Temsky34 Array IndexOf nicht verfügbar Java Basics - Anfänger-Themen 18
belana wie am besten 2D Array von String to Integer Java Basics - Anfänger-Themen 18
S Array mit Methode löschen Java Basics - Anfänger-Themen 2
J Java To String Methode, Array mit For-Schleife Java Basics - Anfänger-Themen 2
E Durch Muster in Array iterieren Java Basics - Anfänger-Themen 3
L Frage zum Array Java Basics - Anfänger-Themen 1
C 2D Array Ausgabe mit for-Schleife i,j Java Basics - Anfänger-Themen 4
D Methode: Array Reihenfolge tauschen Java Basics - Anfänger-Themen 3
julian0507 Array aus Methode in anderer Methode sichtbar machen Java Basics - Anfänger-Themen 10
P Array vom Typ Klasse Java Basics - Anfänger-Themen 18
Lion.King Array deklarieren und initialisieren Java Basics - Anfänger-Themen 5
P Array-Objekte-Aufruf Java Basics - Anfänger-Themen 22
A CSv.Datei einlesen und die werte in zweidemosional Int Array speichern Java Basics - Anfänger-Themen 9
M Methoden Zweidimensionaler Array mit Setter Methode ändern Java Basics - Anfänger-Themen 4
AkiJou Zeile in 2d Array löschen Java Basics - Anfänger-Themen 2
LilliCherry Array in einer Zeile ausgeben Java Basics - Anfänger-Themen 6
A Elemente in einem Array Java Basics - Anfänger-Themen 5
A Vorkommende Farben ermittel und als Array zurückgeben Java Basics - Anfänger-Themen 7
AhmadSlack Array Java Basics - Anfänger-Themen 7
Jambolo Kartenhand Array Java Basics - Anfänger-Themen 14
ravenz Schleife mit for über String Array „zahlen“und prüfen ob Wert „a“ oder „b“ oder „c“ entspricht (mittels || ) Java Basics - Anfänger-Themen 4
S Eine Variable in einem Array speichern Java Basics - Anfänger-Themen 5
T Methode, die prüft ob in einem Int-Array maximal 2 Zahlen enthalten sind, die größer als ihr Vorgänger sind Java Basics - Anfänger-Themen 5
T String Array Fehler beim Index Java Basics - Anfänger-Themen 3
krgewb byte-Array, das ein Bild repräsentiert Java Basics - Anfänger-Themen 1
1 Array rekursiv durchlaufen Java Basics - Anfänger-Themen 8
I Methoden Wieso wird mein Array "a" verändert und meine Variable "a" nicht? Java Basics - Anfänger-Themen 4
EykS 3D Druckdatei basierend auf 3D Array? Java Basics - Anfänger-Themen 3
sserio Array funktioniert nicht Java Basics - Anfänger-Themen 2
sserio Iterierung über ein zweidimensionales Array Java Basics - Anfänger-Themen 16
sserio Zweidimensionales Array [][] wird untereinander ausgegeben Java Basics - Anfänger-Themen 14
Chris.089 2 Werte im Array tauschen Java Basics - Anfänger-Themen 6
D EinMalEins mithilfe einer for-Schleife und Array Java Basics - Anfänger-Themen 1
L Unbekanntes Problem mit 2d Array Java Basics - Anfänger-Themen 6
L Gridmuster in einem Array Java Basics - Anfänger-Themen 2
sgtcoopa Array übergeben Schleife Java Basics - Anfänger-Themen 0
B Compiler-Fehler Array aus Objekten übergeben Java Basics - Anfänger-Themen 7
padde479 Array Multiplikation der ersten n Zahlen Java Basics - Anfänger-Themen 7
G zweidimensionales int Array sortieren Java Basics - Anfänger-Themen 57
W Array ausgeben Java Basics - Anfänger-Themen 29

Ähnliche Java Themen

Neue Themen


Oben