Zweidimensionaler Array; n x m - Matrix überprüfuen

luluuxs

Aktives Mitglied
Guten Abend,
ich soll eine Matrix n x m abfragen und diese dann auf mindestens doppelte Werte überprüfen und diese dann durch eine "-1" ersetzen...
Das Einlesen und Ausgeben funktioniert soweit, nur probiere ich seit mehreren Stunden meine Matrix auf doppelte Werte zu überprüfen und die Werte durch die -1 zu ersetzen, aber ich komme echt nicht mehr weiter.
Hat zufällig wer einen Tipp oder eine Lösung für mich ?
Ich bin für jede kleine Hilfe dankbar.
LG

Bisher sieht mein Code so aus:

(siehe Nachricht weiter unten)
 
Zuletzt bearbeitet:

mihe7

Top Contributor
Bitte Code in Code-Tags posten (im Editor oben links </> klicken).

Wie würdest Du mit Zettel und Stift vorgehen? Kannst Du den Algorithmus in kleinen Schritten skizzieren?
 

luluuxs

Aktives Mitglied
Gute Frage, entweder erst die doppelten Zahlen durchstreichen und dann eine -1 hinschreiben oder alles neu hinschreiben und die doppelten durch -1 ersetzen.

Java:
public class Matrix {

    public static int[][] readIn(int[][] size, int n, int m) {
        int[][] b = new int[n][m];
        for (int i = 0; i < n; i++) {
            Out.println("Geben Sie Zeile " + i + " ein: ");
            for(int j = 0; j < m; j++) {
                b [i][j] =In.readInt();
            }
        }
        return b;
    }

    public static int[][] compareMatrices(int[][] base, int n, int m) {
        boolean compare = false;
        int[][] crossing = new int[n][m];
        for (int a = 0; a < n; a++) {
            for (int b = 0; b < m; b++) {
                for (int c = a+1; c < n; c++) {
                    for (int d = b+1; d < m; d++) {
                        if (base[a][b] == base[c][d]) {
                            compare = true;
                        } else {
                            compare = false;
                        }
                        if (!compare) {
                            crossing[a][b] = (-1);
                            crossing[c][d] = (-1);
                        } else {
                            crossing[a][b] = base[n][m];
                        }
                    }
                }
            }
        }
        return crossing;
    }

    public static void main(String[] args) {
        Out.println("Bitte geben Sie die gewünschte Zeilenanzahl n der Matrix an: ");
        int n = In.readInt();
        Out.println("Bitte geben Sie die gewünschte Spaltenanzahl m der Matrix an: ");
        int m = In.readInt();
        int[][] size = new int[n][m];
        int[][] base= readIn(size, n, m);
        int[][] output = compareMatrices(base, n , m);
        for (int z = 0; z < n; z++) {
            Out.println();
            for (int y = 0; y < m; y++) {
                Out.print(output[z][y] + " ");
            }
        }
    }
}
 

luluuxs

Aktives Mitglied
"Gute Frage, entweder erst die doppelten Zahlen durchstreichen und dann eine -1 hinschreiben oder alles neu hinschreiben und die doppelten durch -1 ersetzen."
hatte bearbeitet D:
Also ich würde im eingelesenen Array jeden Wert mit jedem vergleichen
Mindestens doppelte Werte streichen
Nur einmal verkommene Werte übernehmen und durchgestrichene durch -1 ersetzen
 

mihe7

Top Contributor
Das ist zu ungenau. Du musst etwas finden wie: ich schaue mir die erste Zahl der Matrix in Zelle (0,0) an, dort steht eine Zahl x. Dann ... dann... wenn... dann... wiederhole... usw.:)
 

mihe7

Top Contributor
Wenn Dir das zu schwer ist, dann machen wir das auf zwei Schritte:

Ich sage Dir eine Zahl y. Formuliere einen Algorithmus, der alle y in der Matrix durch -1 ersetzt.
 

luluuxs

Aktives Mitglied
Ich schaue mir die Zelle (0,0) an, vergleiche diese mit allen anderen Zellen der Matrix auf gleiche Werte
Wenn ein Wert gleich ist, wird dieser gestrichen, alle anderen Werte werden in einen neuen Array gespeichert.
Werte die gleich waren werden im neuen Array durch eine -1 ersetzt.
Dies wiederhole ich mit allen Zellen (n, m)
 

mihe7

Top Contributor
Du könntest ja vorher die Matrix kopieren und z. B. sagen: wenn sich Zelle (x,y) in Matrix A von Zelle (x,y) in Matrix B unterscheidet, dann wurde die Zelle in Matrix A gelöscht.
 

mihe7

Top Contributor
Sorry, war ein Gedankenfehler meinersetits (premature optimization is the root of all evil...)

Löschen heißt also einfach auf -1 setzen?
 

mihe7

Top Contributor
So, jeden Wert w in der Matrix durch -1 zu ersetzen bekommst Du hin, oder?

Dann wäre die nächste Aufgabe: jeden Wert w in der Matrix ab einer bestimmten Zelle (x,y) in der Matrix durch -1 zu ersetzen.
 

luluuxs

Aktives Mitglied
So, jeden Wert w in der Matrix durch -1 zu ersetzen bekommst Du hin, oder?

Dann wäre die nächste Aufgabe: jeden Wert w in der Matrix ab einer bestimmten Zelle (x,y) in der Matrix durch -1 zu ersetzen.
warum "ab" ? Nur für bestimmte
Ich denke, ich weiß wie ich Werte ersetze, aber irgendetwas habe ich in meinem Code ja falsch ._.
 

luluuxs

Aktives Mitglied
Code:
0 0 0 0 w 0 0 0
0 0 w 0 0 0 0 w
Alle w durch -1 ab Zelle (0,6) -->
Code:
0 0  0 0 w 0 0  0
0 0 -1 0 0 0 0 -1
das macht Sinn
Leider ist bei meiner Methode compareMatrices aber ein Fehler dadurch, dass ich c = a+1 und d = b+1 gesetzt habe, aber ich weiß nicht wie ich das ändere, so das es dann funktioniert..
 

mihe7

Top Contributor
Java:
                        if (base[a][b] == base[c][d]) {
                            compare = true;
                        } else {
                            compare = false;
                        }
                        if (!compare) {
                            crossing[a][b] = (-1);
                            crossing[c][d] = (-1);
                        } else {
                            crossing[a][b] = base[n][m];
                        }
Was soll dieses compare-Zeugs? Erstmal entfernen:
Java:
                        if (base[a][b] == base[c][d]) {
                            crossing[a][b] = base[n][m];
                        } else {
                            crossing[a][b] = (-1);
                            crossing[c][d] = (-1);
                        }
So, warum base[n][m]?
 

luluuxs

Aktives Mitglied
Java:
                        if (base[a][b] == base[c][d]) {
                            compare = true;
                        } else {
                            compare = false;
                        }
                        if (!compare) {
                            crossing[a][b] = (-1);
                            crossing[c][d] = (-1);
                        } else {
                            crossing[a][b] = base[n][m];
                        }
Was soll dieses compare-Zeugs? Erstmal entfernen:
Java:
                        if (base[a][b] == base[c][d]) {
                            crossing[a][b] = base[n][m];
                        } else {
                            crossing[a][b] = (-1);
                            crossing[c][d] = (-1);
                        }
So, warum base[n][m]?
compare Zeugs hab ich weggemacht, war unnötig ka, was da mein Plan war
ich dachte wenn der wert nicht doppelt ist, wird in dem neuen array einfach der alte wert aus base gespeichert
da muss auf jeden fall base[a] right?
 

luluuxs

Aktives Mitglied
[CODE lang="java" title="hatte das jetzt so"]public static int[][] compareMatrices(int[][] base, int n, int m) {
int[][] crossing = new int[n][m];
for (int a = 0; a < n; a++) {
for (int b = 0; b < m; b++) {
for (int c = 0; c < n; c++) {
for (int d = 0; d < m; d++) {
if (base[a] == base[c][d]) {
crossing[a] = (-1);
crossing[c][d] = (-1);
} else {
crossing[a] = base[a];
}
}
}
}
}
return crossing;
}[/CODE]
 

mihe7

Top Contributor
Ne, so geht das nicht.

Java:
    public static int[][] kill(int[][] matrix) {
        int[][] result = new int[matrix.length][matrix[0].length];

        for (int i = 0; i < matrix.length; i++) {
            for (int j = 0; j < matrix[0].length; j++) {
                result[i][j] = matrix[i][j];
            }
        }

        for (int i = 0; i < matrix.length; i++) {
            for (int j = 0; j < matrix[0].length; j++) {
                for (int p = i; p < matrix.length; p++) {
                    int start = p == i ? j+1 : 0;
                    for (int q = start; q < matrix[0].length; q++) {
                        if (matrix[i][j] == matrix[p][q]) {
                            result[i][j] = -1;
                            result[p][q] = -1;
                        }
                    }
                }
            }
        }

        return result;
    }
 

luluuxs

Aktives Mitglied
Ne, so geht das nicht.

Java:
    public static int[][] kill(int[][] matrix) {
        int[][] result = new int[matrix.length][matrix[0].length];

        for (int i = 0; i < matrix.length; i++) {
            for (int j = 0; j < matrix[0].length; j++) {
                result[i][j] = matrix[i][j];
            }
        }

        for (int i = 0; i < matrix.length; i++) {
            for (int j = 0; j < matrix[0].length; j++) {
                for (int p = i; p < matrix.length; p++) {
                    int start = p == i ? j+1 : 0;
                    for (int q = start; q < matrix[0].length; q++) {
                        if (matrix[i][j] == matrix[p][q]) {
                            result[i][j] = -1;
                            result[p][q] = -1;
                        }
                    }
                }
            }
        }

        return result;
    }
danke
 

mihe7

Top Contributor
Musst Du Dir nochmal anschauen, ich hab das nur runtergerotzt und heute ist nicht mein Tag. Das Problem in Deinem Code ist, dass Du im else-Zweig Dir ja immer wieder die Werte überschreibst.
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
Ostkreuz Zweidimensionaler Array Index Java Basics - Anfänger-Themen 2
M Methoden Zweidimensionaler Array mit Setter Methode ändern Java Basics - Anfänger-Themen 4
G Nochmal zweidimensionaler Vector Java Basics - Anfänger-Themen 10
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
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
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

Ähnliche Java Themen

Neue Themen


Oben