2D Array, Symmetrische Matrix

Honky

Mitglied
Erzeugen Sie ein nxn
Array vom Typ boolean und befüllen Sie es mit zufälligen Werten. Beachten Sie
dabei aber folgende Einschränkungen:
• Die durch das Array dargestellte quadratische Matrix soll symmetrisch sein.
• Die Werte auf der Hauptdiagonalen sollen immer false sein.
• 3 <= n <= 9 Geben Sie den Inhalt des Arrays in folgendem Format am Bildschirm aus (im Beispiel mit n=5):


Meine Frage:
Versteht irgendjmd. die Aufgabe ?

Ich hab den Anfang mal gemacht, aber ich versteh den letzten Punkt der Aufgabe nicht.
quadratische Matrix erstellen no prob. Befüllen auch no prob.

Das mit der Symmetrie hab ich so gelöst, das schon beim Erstellen immer auf Symmetrie geachtet wird, sonst wird das Array einfach wieder überschrieben, solange bis Symmetrie vorhanden ist. (Bedingung für Symmetrie: matrix[a] = matrix[a] )

So ich weiß nun nicht wie ich diese Bedingung in die DoWhile schleife quetsche, dafür bräuchte ich ja zwei for schleifen. Und will nicht alle möglichen Kombinationen abprüfen.

Code:
public class Symmetrie {
    public static void main(String[] args) {
        int n = 5;
        boolean[][] matrix = new boolean[n][n];     //nxn Matrix

        // Matrix befüllen
        do {
            for (int i = 0; i < matrix.length; i++) {
                for (int j = 0; j < matrix[i].length; j++) {
                    matrix[i][j] = Math.random() < 0.5;                 //Zufälliger boolean Wert
                    System.out.print(matrix[i][j] + " ");
                }
                System.out.println();
            }
        }while(matrix[0][1] != matrix[1][0] == true && matrix[0][2] != matrix[2][0] == true &&matrix[0][3] != matrix[3][0] == true && matrix[0][4] != matrix[4][0] == true);
    }
}
 

Anhänge

  • esop.jpg
    esop.jpg
    19,8 KB · Aufrufe: 44

httpdigest

Top Contributor
Kleiner Tipp: Du weißt doch, dass die Matrix symmetrisch sein soll. In dem Fall brauchst du ja gar nicht alle nxn Felder mit zufälligen Werten solange zu befüllen bis sie zufällig symmetrisch sind... was man daraus jetzt aber folgen kann, darauf musst du selber kommen. :)
 

Honky

Mitglied
Ja ich könnte sie einfach perhand befüllen und Symmetrisch machen, will aber lieber eine allgemeine Lösung, weil dann kann ich das auch noch für andere Aufgaben verwenden.
 

httpdigest

Top Contributor
Ja ich könnte sie einfach perhand befüllen und Symmetrisch machen[...]
Per Hand befüllen? Was meinst du damit? Du sollst schon einen allgemeinen Algorithmus entwickeln, der dir (in angemessen schneller Zeit) eine symmetrische nxn Matrix mit zufälligen Werten generieren kann. Und weiterer kleiner Tipp: Du kannst den Algorithmus so effizient gestalten, dass du sogar 1000x1000 Matrizen in wenigen Millisekunden generieren kannst.
 

MoxxiManagarm

Top Contributor
Ein boolean ist default false. d.h. beim Intialisieren ist die Hauptdiagonale bereits richtig.

Im Fall 5x5 brauchst du dann noch (und die spiegelverkehrten)
0/1 0/2 0/3 0/4
1/2 1/3 1/4
2/3 2/4
3/4

also brauchst du nur soeine Schachtelung zum Befüllen:
Java:
for (int i = 0; i < matrix.length - 1; i++) {
    for (int j = i+1; j < matrix[i].length; j++) {
        matrix[i][j] = matrix[j][i] = randomBoolean();
    }
}

Die Ausgabe würde ich hinterher machen und nicht während des Befüllens
 

httpdigest

Top Contributor
also brauchst du nur soeine Schachtelung zum Befüllen:
Java:
for (int i = 0; i < matrix.length - 1; i++) {
    for (int j = i+1; j < matrix[i].length; j++) {
        matrix[i][j] = matrix[j][i] = randomBoolean();
    }
}
Auch diesen Algorithmus kann man noch optimieren. :)
Java:
boolean[] matrix = new boolean[n * n];
Random rnd = new Random();
for (int r = 0; r < n; r++) {
    for (int c = 0; c < r; c++) {
        matrix[n * r + c] = matrix[n * c + r] = rnd.nextBoolean();
    }
}
 

MoxxiManagarm

Top Contributor
Mag ja sein, dass diese Variante noch etwas effizienter ist, aber die Aufgabe sieht aus meiner Sicht klar ein 2D-Array vor und vermutlich ist die 2D Variante für einen Anfänger auch verständlicher.

randomBoolean() war bei mir übrigens nur ein Platzhalter. Random.nextBoolean() hätte auch ich gewählt - gute Wahl ;-)
 
Zuletzt bearbeitet:

MoxxiManagarm

Top Contributor
Also ich kann auf jeden Fall bestätigen, dass die 1-dimensionale Variante schneller ist.
bei n=20000 liefen die beiden Varianten bei mir:
2D: 4366ms
1D: 4056ms

Im Vergleich dazu kommt die 1D-Variante beim Index schneller an seine Grenzen. Zwar erst bei n=46341 aber hey x)
 
Zuletzt bearbeitet:

Honky

Mitglied
Warum geht das bei mir nicht, selbst wenn ich

Code:
for (int i = 0; i < matrix.length - 1; i++) {
    for (int j = i+1; j < matrix[i].length; j++) {
        matrix[i][j] = matrix[j][i] = Math.random < 0.5;
    }
}
verwende, kommt irgendeine unsymmetrische Matrix raus. Wenn sie symmetrisch ist, sollte die Hauptdiagonale doch immer stimmen.
 

Honky

Mitglied
Code:
public static void main(String[] args) {
    int n = 5;
    boolean[][] matrix = new boolean[n][n];     //nxn Matrix

    // Matrix befüllen

        for (int i = 0; i < matrix.length; i++) {
            for (int j = 0; j < matrix[i].length; j++) {
                matrix[i][j] = matrix[j][i] = Math.random() < 0.5;                 //Zufälliger boolean Wert
                if(matrix[i][j] == true)
                    System.out.print("* ");                              //True wird durch das Sternchen ersetzt
                else{System.out.print(" ");}                        //False durch ein Leerzeichen
            }
            System.out.println();
        }

}
 

MoxxiManagarm

Top Contributor
Deine Schleifen durchlaufen das komplette Array vergleiche sie nochmal mit meinen. Nochmal der dringende Hinweis: mach die Ausgabe nach dem Befüllen nicht währenddessen
 

Honky

Mitglied
Danke, ich denke ich habs nun.

Code:
public static void main(String[] args) {
    int n = 5;
    boolean[][] matrix = new boolean[n][n];     //nxn Matrix

    // Matrix befüllen

    for (int i = 0; i < matrix.length; i++) {
        for (int j = i; j < matrix[i].length; j++) {
            if(i==j)
                matrix[i][j]=false;
            else
            matrix[i][j] = matrix[j][i] = Math.random() < 0.5;                 //Zufälliger boolean Wert
                                  //False durch ein Leerzeichen
        }


    }

    for(int i =0; i<matrix.length; i++){
        for (int j = 0; j < matrix[i].length; j++) {
            System.out.print(matrix[i][j] + ",");
        }
        System.out.println();
    }

}
 
Ä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