Muster in 2D-Array finden

BDA

Mitglied
Hallo! ;)

Ich versuche im Moment, bestimmte (in einem Array gespeicherte) Muster in einem anderen Array zu finden. Die "große Liste" cells ist eine 2D-Liste von booleans. Ich übergebe der Methode ein Muster, wobei eine 0 für false, eine 1 für true und eine 2 für eins von beidem steht. Die Methode gibt 2 Integer als Array zurück, und zwar die x + y Koordinate des (ersten) gefundenen Musters. Ein Beispiel für ein Muster:
Code:
 { { 1, 1, 1, 1 , 2, 0, 1}}
Das Problem: er erkennt das Muster auch, wenn es rotiert ist (um 90°). Wahrscheinlich habe ich einfach irgendwo nicht nachgedacht... Kann mir einer von euch helfen? *-* Falls etwas sinnlos erscheint, es hat alles seinen Sinn! Ich weiß, der Code könnte effizienter sein, aber erstmal ist mir wichtig das er funktioniert...
Java:
private int[] checkForPatterns(int[][] pattern) {

		for (int x = 0; x < cells.length; x++) {
			for (int y = 0; y < cells[0].length; y++) {
				int counter = 0;
				for (int pX = 0; pX < pattern.length; pX++) {
					for (int pY = 0; pY < pattern[0].length; pY++) {
						System.out.println(pattern.length + " + "
								+ pattern[0].length);
						try {
							switch (pattern[pX][pY]) {
							case 0:
								if (cells[x + pX][y + pY] == false)
									counter++;
								break;
							case 1:
								if (cells[x + pX][y + pY] == true)
									counter++;
								break;
							case 2:
								counter++;
								break;
							}
						} catch (Exception e) {
						}
					}
				}
				if (counter == pattern.length * pattern[0].length) {
					return new int[] { x, y };
				}
			}
		}

		return null;
	}
MFG, me
 
Zuletzt bearbeitet:

Flown

Administrator
Mitarbeiter
Also nocheinmal alles zusammenzufassen: Du hast ein 2D Array und da sind irgendwelche Wert (0-2) und du willst nach einem gewissen Muster ausschau halten.

Soll das Muster nur horizontal funktionieren? Oder soll es auch in jede Richtung gelten?

Oder sagen wir so, wenn du so ein Pattern {{2, 2, 2, 2, 1}} erstellst, dann soll es nur horizontal und wenn du {{2},{2},{2},{1}} erstellst soll es vertikal gesucht werden?
 

BDA

Mitglied
Also nocheinmal alles zusammenzufassen: Du hast ein 2D Array und da sind irgendwelche Wert (0-2) und du willst nach einem gewissen Muster ausschau halten.

Soll das Muster nur horizontal funktionieren? Oder soll es auch in jede Richtung gelten?

Oder sagen wir so, wenn du so ein Pattern {{2, 2, 2, 2, 1}} erstellst, dann soll es nur horizontal und wenn du {{2},{2},{2},{1}} erstellst soll es vertikal gesucht werden?

Genau so, habe es wahrscheinlich nur ein bisschen undurchsichtig erklärt...
 

Flown

Administrator
Mitarbeiter
Sowas in derer Art?

Java:
import java.util.Arrays;

public class ArrayPatternMatcher {
	
	public static void main(String[] args) {
		
		boolean[][] testGrid = {{false, false, true, true},
								{true, false, true, false},
								{false, false, false, false}};
		int[][] pattern = {{2}, {0}, {0}};
		
		System.out.println(Arrays.toString(findPatternInGrid(testGrid, pattern)));
		
	}
	
	public static int[] findPatternInGrid(boolean[][] grid, int[][] pattern) {
		int[] result = null;
		for(int i = 0; i < grid.length; i++) {
			for(int j = 0; j < grid[i].length; j++) {
				if(findPatternInGridAt(i, j, grid, pattern)) {
					return new int[] {i, j};
				}
			}
		}
		return result;
	}
	
	private static boolean findPatternInGridAt(int x, int y, boolean[][] grid, int[][] pattern) {
		for(int i = 0; i < pattern.length; i++) {
			if(pattern.length > grid.length - x) return false;
			if(pattern[i].length > grid[i].length - y) return false;
			for(int j = 0; j < pattern[i].length; j++) {
				switch(pattern[i][j]) {
				case 0:
					if(grid[x+i][y+j]) {
						return false;
					}
					break;
				case 1:
					if(!grid[x+i][y+j]) {
						return false;
					}
					break;
				}
			}
		}
		return true;
	}

}
 

BDA

Mitglied
Sowas in derer Art?

Java:
import java.util.Arrays;

public class ArrayPatternMatcher {
	
	public static void main(String[] args) {
		
		boolean[][] testGrid = {{false, false, true, true},
								{true, false, true, false},
								{false, false, false, false}};
		int[][] pattern = {{2}, {0}, {0}};
		
		System.out.println(Arrays.toString(findPatternInGrid(testGrid, pattern)));
		
	}
	
	public static int[] findPatternInGrid(boolean[][] grid, int[][] pattern) {
		int[] result = null;
		for(int i = 0; i < grid.length; i++) {
			for(int j = 0; j < grid[i].length; j++) {
				if(findPatternInGridAt(i, j, grid, pattern)) {
					return new int[] {i, j};
				}
			}
		}
		return result;
	}
	
	private static boolean findPatternInGridAt(int x, int y, boolean[][] grid, int[][] pattern) {
		for(int i = 0; i < pattern.length; i++) {
			if(pattern.length > grid.length - x) return false;
			if(pattern[i].length > grid[i].length - y) return false;
			for(int j = 0; j < pattern[i].length; j++) {
				switch(pattern[i][j]) {
				case 0:
					if(grid[x+i][y+j]) {
						return false;
					}
					break;
				case 1:
					if(!grid[x+i][y+j]) {
						return false;
					}
					break;
				}
			}
		}
		return true;
	}

}
Das klappt jetzt, danke!!!
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
I Muster in Array suchen Allgemeine Java-Themen 10
Meeresgott OOP Factory Muster ausbauen Allgemeine Java-Themen 34
M Alles außer Muster in String ersetzen Allgemeine Java-Themen 1
W String Parsen und auf eigenes Muster anwenden (kein Regex) Allgemeine Java-Themen 11
L Strings nach gleichem Muster ordnen Allgemeine Java-Themen 4
G ThreadLocal in Muster "Unit of Work" Allgemeine Java-Themen 7
D Sterne Muster mit einer Schleife Allgemeine Java-Themen 5
K ArrayList nach bestimmtem Muster sortieren Allgemeine Java-Themen 3
S Kompositum Muster ohne Exception oder instanceof Operator Allgemeine Java-Themen 6
M RegEx: Muster ersetzen Allgemeine Java-Themen 6
T Muster/Zeichen/Texterkennung auf einem Image Allgemeine Java-Themen 9
G String nach Muster durchsuchen Allgemeine Java-Themen 5
X Bestimmtes Muster in Textdatei verändern Allgemeine Java-Themen 13
K Sequenzdiagramm für Singleton-Muster Allgemeine Java-Themen 5
M Rekursiv Verzeichnisse ansehen und auf Muster matchen Allgemeine Java-Themen 6
LucasGlockner Effizienter byte-Zugriff auf ein long[]-Array Allgemeine Java-Themen 8
8u3631984 Frage Performance bei Linked List und Array List Allgemeine Java-Themen 5
M Queue mit einem Array implemetieren Allgemeine Java-Themen 16
M Array Rang eines Elements Allgemeine Java-Themen 4
TheSepp Java bestimmtes Array auf den Wert 0 setzen Allgemeine Java-Themen 32
TheSepp Wie kann man Leerzeichen aus einer Array liste entfernen? Allgemeine Java-Themen 10
B HeapSort für Array of Strings funktioniert nur teilweise Allgemeine Java-Themen 3
noah1407 Array Allgemeine Java-Themen 3
D Methoden Teil-Array mit Maximalwert bestimmen Allgemeine Java-Themen 23
N einem Array Objekte hinzufügen die ihr Array position gespeichert haben Allgemeine Java-Themen 34
N zweidimensionalen Array in dreidimensionalen Array speichern Allgemeine Java-Themen 4
N Schnellste Methode, ein Array durchzugehen? Allgemeine Java-Themen 9
T Objekt Array Aufgabe mit Busdatenbank Allgemeine Java-Themen 2
L Array und Index Allgemeine Java-Themen 26
L die 3 größten Zahlen im Array Allgemeine Java-Themen 1
G jToggleButton in Array/ArrayList Allgemeine Java-Themen 12
S Übergabe eines Sortierkriteriums für ein Artikel Array mittels BiPredicate<Artikel, Artikel> Allgemeine Java-Themen 13
Willi.We Array sortieren Allgemeine Java-Themen 5
gotzi242 Array Summe bestimmen tipps? Allgemeine Java-Themen 14
H Matrix ohne Array erstellen Allgemeine Java-Themen 9
Aboya Char Array rekursiv vergleichen Allgemeine Java-Themen 15
V4ll3.Wff Array in Java Allgemeine Java-Themen 4
Noahscript Aus einem byte Array Steuerungszeichen und Code bekommen und ersetzen Allgemeine Java-Themen 3
H Array Sportschütze Allgemeine Java-Themen 6
Sumo_ow "ArrayIndexOutofBoundsException: 2" Array Problem Allgemeine Java-Themen 6
xGh0st2014 Problem mit Java Array Allgemeine Java-Themen 1
M Array verändern Allgemeine Java-Themen 1
A JavaFX 2 dimensionales array Allgemeine Java-Themen 1
LimDul Direktes return eines Array geht nicht Allgemeine Java-Themen 20
S Array dynamisieren oder ArrayList verwenden? Allgemeine Java-Themen 17
M Java 2D Array für ein Grid erstellen ? Allgemeine Java-Themen 2
H Array mit dem Datentype String[] initializieren Allgemeine Java-Themen 7
L ArrayList mit String Arrays in ein Array umwandeln Allgemeine Java-Themen 1
H Elemente aus ArrayList in Array speichern Allgemeine Java-Themen 8
E Datentypen Wie kann ich die Längen der unterschiedlichen Ebenen aus einem Objekt lesen von dem ich weiß, dass es ein mehrdimensionaler Array ist? Allgemeine Java-Themen 3
N Byte Array in Java "dekomprimieren" Allgemeine Java-Themen 3
parrot Array Aufgabe Allgemeine Java-Themen 3
N String Array Eingabe Allgemeine Java-Themen 6
R Warum wird mir in der Konsole das "Standard Array" ausgegeben? Allgemeine Java-Themen 2
N Variablen Array Länge ändern. Allgemeine Java-Themen 8
D Kgv aller Paare aus einem Array mit n integer berechnen Allgemeine Java-Themen 5
W Enumeration ein Array/List als Eigenschaft mitgeben - warum geht das nicht? Allgemeine Java-Themen 0
kodela Problem mit strukturiertem Array Allgemeine Java-Themen 18
A Array Problem Allgemeine Java-Themen 8
Drachenbauer Wie stelle ich fest, ob ein Objekt in meinem Array vorkommt? Allgemeine Java-Themen 5
F Datei in String-Array einlesen Allgemeine Java-Themen 8
L Objekt aus Objekt-array "löschen" Allgemeine Java-Themen 2
I Array Parameter mit 2 Klassen - NullPointerException Allgemeine Java-Themen 3
X Größten Werte in meinem Array löschen? Allgemeine Java-Themen 16
E Angabe wie groß Array sein soll und in for-schleifen diesen Array füllen Allgemeine Java-Themen 3
F 3 Dimensionales Array mit Allgemeine Java-Themen 9
M Steueralgorithmus verwandelt Array in Anfangszustand Allgemeine Java-Themen 9
W Array vs. ArrayList vs. HashMap Allgemeine Java-Themen 20
D Datentypen 2-3 Baum erstellen mit geordnetem int-array Allgemeine Java-Themen 0
T Objekt in Array packen Allgemeine Java-Themen 6
M Zahlen in Array anordnen Allgemeine Java-Themen 8
M Eclipse Unvollständigen Array ansteuern Allgemeine Java-Themen 2
D Erste Schritte Im Array Werte tauschen Allgemeine Java-Themen 5
Xge For/Array Error: IndexOutOfBounds Allgemeine Java-Themen 4
M Wie kann ich ein int[] Array in einer Methode benutzen? Allgemeine Java-Themen 6
FRI3ND Datentypen Date-Array sortieren - Text mitnehmen? Allgemeine Java-Themen 7
D Integer-Array variabler Größe mit Zahlen befüllen (Schleifen) Allgemeine Java-Themen 0
J Variablen Array ertellen bei model.put Allgemeine Java-Themen 13
S Eindimensionales Array in zweidimensionales Array speichern Allgemeine Java-Themen 5
R convert 2d array list to 2d array Allgemeine Java-Themen 1
J json Array würfel Spalten durcheinander Allgemeine Java-Themen 9
MiMa Array umbau oder Alternative? Allgemeine Java-Themen 5
L Datentypen 3D Array Allgemeine Java-Themen 3
M 2D Array mit unterschiedlichen Längen erstellen und befüllen Allgemeine Java-Themen 11
Mario1409 Methoden JSON Array von URL Allgemeine Java-Themen 8
E Swing Array mit Bildern in GUI darstellen Allgemeine Java-Themen 2
P Array einer abstrakten Klasse Allgemeine Java-Themen 4
H Zweidimensionales Array - Zellen der Tabelle verbinden Allgemeine Java-Themen 2
M Zweidimensionales Array mit Binärzahlen füllen Allgemeine Java-Themen 8
M Array aus Thread Objekten erstellen Allgemeine Java-Themen 2
kodela Dynamisches Array in einer Klasse Allgemeine Java-Themen 5
G Array ohne Aufzählungszeichen ausgeben Allgemeine Java-Themen 6
J Wie kann ich ein Java Array als Säulendiagramm ausgeben? Allgemeine Java-Themen 2
Z 2D Array Pixels reparieren Allgemeine Java-Themen 2
S Algorithmus welcher True-Werte in einem Array findet und auswertet. Allgemeine Java-Themen 5
B Polibios Array erweitern Allgemeine Java-Themen 1
R Index in einem Array löschen Allgemeine Java-Themen 10
R Index in einem Array löschen Allgemeine Java-Themen 2
U Methoden Algorithmus MergeSort String [ ] array sortieren programmieren Allgemeine Java-Themen 17
J Array-List Bubble-Sort Allgemeine Java-Themen 12

Ähnliche Java Themen

Neue Themen


Oben