Array - rekursion

pe81

Mitglied
hi an alle,

habe mal eine frage bezüglich der rekursion und arrays.
ich habe ein bild z.b. bild[]

ppppppg
pgpppgg
gggppgp
pgppgpp
pggggpp

ich habe eine methode, wo ich als Parameter das bild habe und die position im bild z.b. 1/2 und ein char z.b. R, welches an der Position ersetzt werden soll.

jetzt soll das g an der Position 1/2 durch R ersetzt werden und alle Nachbarn(Vierer-Nachbarschaft von g, wenn ein g vorhanden ist sollen rekursiv aufgerufen werden und geändert werden).

z.b die g's auf der Positionen 0/6,1/6 und 2/5 sollen nicht geändert werden da sie keine Vierer-Nachbarschaft mit anderen g's darstellen.
Java:
public static void einfuege(String[] bild, int x, int y, char c){


}

Danke für den Input...ich habe ein wenig probleme mit dem algorithmus wie man den am besten zusammenstellt um sowas zu programmieren.

LG
PE
 

pe81

Mitglied
hi,

ich weiss wie man es ersetzt nur es geht eher darum wie ich die mehtode einfuege rekursiv einsetze
und dann die nachbarn von einem bestimmten zeichen bestimme wie oben erläutert...

lg
pe
 
T

Tomate_Salat

Gast
Lösungen gibts hier keine. Aus den Koordinaten die du hast, welchen Buchstaben du ändern willst, kannst du dir die anderen ableiten, die du prüfen musst.

Mach dir mal selber Gedanken. Wenn es dann irgendwo kracht helfen wir gerne. Aber einfach die Aufgabe posten und die Methode, in der das geschehen soll ist definitiv zu wenig Eigeninitiative.
 

pe81

Mitglied
hallo,

ich wollte auch nicht, dass mir jemand die aufgabe löst....vielleicht ist das ein wenig falsch rübergekommen......ich habe hier nur um einwurfgedanken gebeten, wie man das am besten angehen sollte......

hier mal meine gedanken.....

ppppppg
pgpppgg
gggppgp
pgppgpp
pggggpp
Java:
public static void einfuege(String[] bild, int x, int y, char c){

// Das ist ein char in meinem bespiel z.b 'g' 
char aa = bild[eingabezahl2].charAt(eingabeZahl1);
	

if(bild[y].charAt(x) == aa){

// hier wird das zeichen ersetzt
bild[y] = bild[y].substring(0, x) + c + bild[y].substring(x+1);

// rufe ich die methode rekursiv wieder auf
einfuege(bild,x-1,y,c);

}
und jetzt fehlt mir der schritt wie ich es für alle felder machen könnte.....wenn der nachbar auch ein 'g' hat.

thx
lg
Pe
 
S

SlaterB

Gast
in Zeile 13 hast du doch schon einen rekursiven Aufruf,
was spricht gegen 3 weitere mit anderen Koordinaten für die anderen Richtungen?
 

pe81

Mitglied
hi, das ist auch mein gedanke, aber ich würde gerne wieder von der position x-1 nachchecken ob die nachbarn das selbe zeichen haben.....

thx
lg
PE
 
S

SlaterB

Gast
das ist eigentlich nicht nötig, soweit ich das überblicke,
aber steht es dir natürlich frei, z.B. in weiteren Parametern die Koordinaten des vorherigen Eintrags zu übergeben, oder nur den jeweilgen char
(der immer aa sein dürfte, vom ersten Aufruf abgesehen)

oder was auch immer du möchtest: einfach machen ;)
 
S

SlaterB

Gast
was ich damit meine dürfte klar sein, warum ist vielleicht eher fraglich,
aber probiere es doch aus, wann wird überhaupt rekursiv aufgerufen, welche Felder betrifft das, wird dort dann korrekt gearbeitet usw?

ich denke du startest bei einem Feld und gehst nur bei korrekten 'g' zu den Nachbarn,
dort wird auch nur bei 'g' weitergearbeitet, sogar Rückkehr zum Ursprung ist nicht schlimm weil das inzwischen auf 'R' geändert worden ist,
man muss sich also auch nicht merken wo man schon war,
usw., ich vermute dass es läuft, entscheidend sind eh nur deine Testläufe, teste alles, schaue alles an
 

pe81

Mitglied
wenn ich jetzt im code die rekursionsmethoden erweitere wie unten...... dann sollte es halbwegs klappen
oder verstehe ich das wieder falsch....

Java:
public static void einfuege(String[] bild, int x, int y, char c){
 
// Das ist ein char in meinem bespiel z.b 'g' 
char aa = bild[eingabezahl2].charAt(eingabeZahl1);
    
 
if(bild[y].charAt(x) == aa){
 
// hier wird das zeichen ersetzt
bild[y] = bild[y].substring(0, x) + c + bild[y].substring(x+1);
 
// rufe ich die methode rekursiv wieder auf
einfuege(bild,x-1,y,c);
einfuege(bild,x,y-1,c);
einfuege(bild,x+1,y,c);
einfuege(bild,x,y+1,c);
 
}

lg
pe
 
S

SlaterB

Gast
das war meine Aussage der letzten 3 Postings, ja..
ob es klappt muss sich erst zeigen (wäre bereits einen Versuch vor deinem Posting durchaus wert gewesen)

du musst sicherlich noch auf Grenzen achten, dass du nicht aus den Array-Index-Bereich herausfällst,
usw., die Welt ist voller Details, eins nach dem anderen angehen, nicht nur fragen
 

pe81

Mitglied
hi,

ich glaube ich habe ein verstädnisproblem mit der rekursion.......was einfaches ist halt nicht schwer zu verstehen. aber bei mir dreht sich alles im kreis und wird nie erhöht....das x bleibt dann an der unteren grenze und wird nie erhöht......




Java:
public static void einfuege(String[] bild, int x, int y, char c){
 
// Das ist ein char in meinem bespiel z.b 'g' 
char aa = bild[eingabezahl2].charAt(eingabeZahl1);
    
 
if(bild[y].charAt(x) == aa){
 
// hier wird das zeichen ersetzt
bild[y] = bild[y].substring(0, x) + c + bild[y].substring(x+1);
 
// rufe ich die methode rekursiv wieder auf
einfuege(bild,x-1,y,c);
einfuege(bild,x,y-1,c);
einfuege(bild,x+1,y,c);
einfuege(bild,x,y+1,c);

über input über rekursion wäre ich sehr dankbar

lg
PE
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
K Rekursion: Rechenmauer mit Array erstellen Java Basics - Anfänger-Themen 17
B Problem beim grundsätzlichen Verständnis bei Rekursion mit 2-dimensionalen Array Java Basics - Anfänger-Themen 6
T Array Rekursion Java Basics - Anfänger-Themen 1
C Rekursion auf einem Array(negative werte addieren) Java Basics - Anfänger-Themen 4
B Java rekursion minimum von ein array Java Basics - Anfänger-Themen 2
B Rekursion für Array Java Basics - Anfänger-Themen 3
M Rekursion Summe vom Array Java Basics - Anfänger-Themen 2
J Rekursion über int und array gibt zu wenige Werte zurück Java Basics - Anfänger-Themen 5
G Rekursion Rückgabewerte in Array speichern Java Basics - Anfänger-Themen 12
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

Ähnliche Java Themen

Neue Themen


Oben