Array Index out of Bound

Status
Nicht offen für weitere Antworten.

elturco

Mitglied
Hallo zusammen,

ich habe einen DFS code geschrieben, bekomme aber immer die Fehlermeldung ArrayIndexOutOfBound...
Das sieht total durcheinander aus, wäre aber echt cool wenn einer mir mal helfen würde, muss das bis morgen haben...leider

Der Graph ist übrigens in Form eines "Fliegennetzes" sage ich mal


Code:
public class Adjazenzmatrix {
	
	int knotenzahl = 0;
	  int [][] kante;  // in dieser 2-dim. Reihung ("Adjazenzmatrix") wird der Graph..
	                      // .. bzw. werden seine Kanten gespeichert
     
	  public void setzeKnotenzahl (int knZahl)
	  {
		  int zähler = 0;
	    knotenzahl = knZahl;
	    System.out.println(knotenzahl);
	    kante = new int [knotenzahl][knotenzahl];
	    for (int i=0; i < knotenzahl; i++)     // Initialisieren: alle Kanten-
	    {
	    	
	      for (int j=0; j < knotenzahl; j++)
	      {
	    	  setzeKante(i,j,1);
	         }
	    }
	  }
	  void Ausgabe()
	  {
		  for (int i=0; i < knotenzahl; i++)
		  {
		       for (int j=0; j < knotenzahl; j++)
		       {
		    	   System.out.print(kante[i][j]+  "(i,j)"+i + j+"  ");
		       }
		       System.out.println();
		  }
		    
	  }
	  public int holeKnotenzahl ()
	  {
	    return (knotenzahl);	   
	  }

	  public void setzeKante (int von, int bis, int kosten)
	  {
	    kante [von][bis] = kosten;
	    kante [bis][von] = kosten;
	  }

	  public double holeKantenKosten (int von, int bis)
	  {
	    return (kante [von][bis]);
	  }	
	}


Code:
public class DSF extends Adjazenzmatrix{
	
	 boolean [] besucht;     // für Tiefensuche: merkt sich, welche Knoten schon besucht wurden
	  
	  public String tiefensuche_rek (int start, int ziel)
	  {
	    int knZahl = holeKnotenzahl();
	    System.out.println("tttttttttttt"+knZahl);
	    besucht = new boolean[knZahl];      // erzeugt besucht (global definiert für rekSuche)
	    for (int i=0; i<knZahl; i++)        // setzt für alle Knoten besucht auf false, weil..
	    {
	      besucht[i] = false;               // .. die Suche ja noch nicht los gegangen ist
	    }
	    String meldung = rekSuche (start, ziel, 0, "");    // Hier startet die (rekursive) Suche ..
	    if (meldung.equals(""))             // .. und gibt den Weg (oder bei Misserfolg nichts) zurück
	    {
	      meldung = "Kein Weg von "+start+" nach "+ziel+" gefunden!";
	    }
	    return ("Tiefensuche: "+meldung+"\n");
	  }

	  private String rekSuche (int knoten, int ziel, double kosten, String weg)
	  {
	    besucht [knoten] = true;            // Jeder Knoten, der von der Suche betreten wird,
	                                        // wird als besucht markiert
	    if (knoten == ziel)                 // Ziel erreicht?
	    {
	      weg = "Weg gefunden (Gesamt="+kosten+"): "+ziel;
	    }
	    else                                // Ziel noch nicht erreicht? Dann zu einem unbesuchten Nachbarn
	    {                                   // ..gehen und von dort den Weg zum Ziel suchen:
	      for (int nachbar = 0; nachbar < knotenzahl && !weg.startsWith("Weg gefunden"); nachbar++)
	      {                                 // Fürs Backtracking nach und nach alle Nachbarn prüfen!
	        if ((!besucht[nachbar]) && (holeKantenKosten (knoten, nachbar) < Double.POSITIVE_INFINITY))
	        {
	          weg = rekSuche (nachbar, ziel, kosten+holeKantenKosten(knoten,nachbar), weg);
	        }
	      }
	      if (weg.startsWith("Weg gefunden"))
	      {
	        weg = weg+"<-"+knoten;          // Bei Rekursions-Rückweg nach Erfolg: Knoten zur 
	      }                                 // Wegbeschreibung dazu. Sackgassen werden nicht notiert!
	    }
	    return (weg);
	  }
	  
}
Code:
public class Main {
	
	public static void main(String args[])
	{

		int n =0;
		Adjazenzmatrix neu = new Adjazenzmatrix();
		
		/*
		 * Von/Nach  0  1  2  3  4  5  6  7  8  9
		 * ------------------------------------------------
		 *   ->   0  
		 *   ->   1
		 *   ->   2
		 *   ->   3
		 *   ->   4
		 *   ->   5
		 *   ->   6
		 *   ->   7
		 *   ->   8
		 *   ->   9
		 
		neu.setzeKnotenzahl(10);
		neu.Ausgabe();
		
		
		 
		
		System.out.println("hhhhhhhhh"+neu.knotenzahl);
		System.out.println("kostentest1:"+neu.holeKantenKosten(0,5));
		System.out.println("kostentest2:"+neu.holeKantenKosten(2,3));
		System.out.println("kostentest3:"+neu.holeKantenKosten(3,5));
		System.out.println("kostentest4:"+neu.holeKantenKosten(0,5));
		
		 
		
		
		
		
		
		System.out.println("kosten:"+neu.holeKantenKosten(0,1));
		System.out.println("kosten:"+neu.holeKantenKosten(1,2));
		System.out.println("kosten:"+neu.holeKantenKosten(2,3));
		System.out.println("kosten:"+neu.holeKantenKosten(3,4));
		System.out.println("kosten:"+neu.holeKantenKosten(4,5));
		System.out.println("kosten:"+neu.holeKantenKosten(5,6));
		System.out.println("kosten:"+neu.holeKantenKosten(3,7));
		System.out.println("kosten:"+neu.holeKantenKosten(7,8));
		System.out.println("kosten:"+neu.holeKantenKosten(8,9));
        System.out.println("kosten:"+neu.holeKantenKosten(9,2));
        
        DSF test = new DSF();
        
        
        System.out.println("test 1"+neu.holeKnotenzahl());
        test.tiefensuche_rek(8,9);
		
	}

	}
public class Main {
	
	public static void main(String args[])
	{

		int n =0;
		Adjazenzmatrix neu = new Adjazenzmatrix();
		
		/*
		 * Von/Nach  0  1  2  3  4  5  6  7  8  9
		 * ------------------------------------------------
		 *   ->   0  
		 *   ->   1
		 *   ->   2
		 *   ->   3
		 *   ->   4
		 *   ->   5
		 *   ->   6
		 *   ->   7
		 *   ->   8
		 *   ->   9
		 
		 
		 
		 */
		
		
		
		
		/*while(i<10)
		{
			while(j<10)
			{
				neu.setzeKante(i, j,1);
				
			}
			j++;	
		}
		i++;
		*/
		neu.setzeKnotenzahl(10);
		neu.Ausgabe();
		/*
		while(m<90)
		{
			while(i<m)
			{
				neu.setzeKante(i,i+1,1);
				System.out.println("wert von i   "+i);
				i++;
			}
			m = m+1;
		}
		
		while(m<=90){
			System.out.println("wert von m2   "+m);
		while(i<9+m)
		{
			System.out.println("wert von i1   "+i);
				neu.setzeKante(i,i+1,1);
				System.out.println("wert von i2   "+i);
				++i;


		}
		System.out.println("wert von m   "+m);
		m=m+10;
		}
		
		*/
	/*	
		while(m<9)
		{

			for(n=0;n<9;n++)
			{   i++;
				neu.setzeKante(i,i+1,1);
				System.out.println("wert von i   "+i);
			}
			m++;
			i=i+10;
			
			
		}
		*/
		
		 
		/*
		for(int p =0 ;p<9;p++)
		{
			neu.setzeKante(p, p+1,1);
		}
		for(int l =0 ;l<9;l++)
		{
			neu.setzeKante(l, l+1,1);
		}
		
		System.out.println("hhhhhhhhh"+neu.knotenzahl);
		System.out.println("kostentest1:"+neu.holeKantenKosten(0,5));
		System.out.println("kostentest2:"+neu.holeKantenKosten(2,3));
		System.out.println("kostentest3:"+neu.holeKantenKosten(3,5));
		System.out.println("kostentest4:"+neu.holeKantenKosten(0,5));
		*/
		/*
		 
		 
		neu.setzeKante(1,2,1);
		neu.setzeKante(2,3,1);
		neu.setzeKante(3,4,1);
		neu.setzeKante(4,5,1);
		neu.setzeKante(5,6,1);
		neu.setzeKante(6,7,1);
		neu.setzeKante(7,8,1);
		neu.setzeKante(8,9,1);
		
		neu.setzeKante(10,11,1);
		neu.setzeKante(11,12,1);
		neu.setzeKante(12,13,1);
		neu.setzeKante(13,14,1);
		neu.setzeKante(14,15,1);
		neu.setzeKante(15,16,1);
		neu.setzeKante(16,17,1);
		neu.setzeKante(17,18,1);
		neu.setzeKante(18,19,1);
		
		
		o---o---o---o---o---o---o---o---o---o
		|   |   |   |   |   |   |   |   |   |
		|   |   |   |   |   |   |   |   |   |
		o---o---o---o---o---o---o---o---o---o
		|                                   |
		|									|
		|									|
		o                                   o
		|                                   | 
		|                                   |
		o									o
		|									|
		|				USW					|
		o									o
		|									|	
		|									|
		o									o
		|									|
		|									|
		o									o	
		|									|
		|									|
		o---o---o---o---o---o---o---o---o---o
		
		
		*/
		
		
		System.out.println("kosten:"+neu.holeKantenKosten(0,1));
		System.out.println("kosten:"+neu.holeKantenKosten(1,2));
		System.out.println("kosten:"+neu.holeKantenKosten(2,3));
		System.out.println("kosten:"+neu.holeKantenKosten(3,4));
		System.out.println("kosten:"+neu.holeKantenKosten(4,5));
		System.out.println("kosten:"+neu.holeKantenKosten(5,6));
		System.out.println("kosten:"+neu.holeKantenKosten(3,7));
		System.out.println("kosten:"+neu.holeKantenKosten(7,8));
		System.out.println("kosten:"+neu.holeKantenKosten(8,9));
        System.out.println("kosten:"+neu.holeKantenKosten(9,2));
        
        DSF test = new DSF();
        
        
        System.out.println("jjjjjjjjjjjj"+neu.holeKnotenzahl());
        test.tiefensuche_rek(8,9);
		
	}

	}
 
B

Beni

Gast
ich habe einen DFS code geschrieben, bekomme aber immer die Fehlermeldung ArrayIndexOutOfBound...
Eine ArrayIndexOutOfBounds bekommt man, wenn man auf ein Element eines Arrays zugreiffen will, das garnicht existiert. z.B.:
Code:
int[] test = new int[2];
int x = test[5]; // zu gross
int y = test[-3], // zu klein

Die Fehlersuche würde ungemein einfacher, wenn du den Fehler - und vorallem die Stelle an der er auftritt - angibst...
 

elturco

Mitglied
ja die Stelle kann ich Dir sagen...

dass ist die Stellen in dem mittleren Code Abschnitt "class DSF extends Add...."
ich rufe die Methode "holeKnotenanzahl" auf aber knZahl wird nicht initialisiert, hat immer noch den Wert 0.
Kannst Du mir da weiterhelfen ?
 
B

Beni

Gast
Ah: du erstellst in der main-Methode ein neues DSF, ein DSF hat zu beginn immer keine Knoten.
Aber dann setzt du nie irgendwelche Knoten, sondern rufst direkt die Tiefensuche auf.
Code:
// Ein neues DSF ohne Knoten erstellen
DSF test = new DSF();

// Die Anzahl Knoten der *alten* Matrix ausgeben
System.out.println("jjjjjjjjjjjj" + neu.holeKnotenzahl());

// Die Tiefensuche auf dem *neuen* DSF (welches keine Knoten hat) aufrufen.
test.tiefensuche_rek(8, 9);
Ein "test.setzeKnotenanzahl( 10 )" sollte wenigstens die Exception webgringen.
 

elturco

Mitglied
@Beni

die Sache ist die die ich habe eine "printf" Ausgabe direkt hinter der Variable "knZahl" gemacht und die ist weiterhin 0,
das kann ich mir gar nicht erklären
 
S

SlaterB

Gast
bei 'neu' ist die Knotenzahl gesetzt,
bei 'test' nicht! dort tritt die Exception auf
->
test.setzeKnotenzahl(10);
wie Beni vorgeschlagen hat und schon ist keine Exception mehr da,
oder neuen Code posten wo noch ein Fehler auftritt


System.out.println("jjjjjjjjjjjj" + test.holeKnotenzahl());
statt
System.out.println("jjjjjjjjjjjj" + neu.holeKnotenzahl());
wäre sicherlich auch hilfreicht,
wobei deine gesamte Variablen- und Logmeldung-Benennung noch zu überarbeiten ist
 
Status
Nicht offen für weitere Antworten.
Ähnliche Java Themen
  Titel Forum Antworten Datum
P Wieso kann ich als Index für einen Array einen Char angeben? Java Basics - Anfänger-Themen 3
melisax Java Array Wert an bestimmtem Index angeben Java Basics - Anfänger-Themen 14
Ostkreuz Zweidimensionaler Array Index Java Basics - Anfänger-Themen 2
T String Array Fehler beim Index Java Basics - Anfänger-Themen 3
M Ersten Index von Array bestimmen Java Basics - Anfänger-Themen 14
M Wie kann eine Methode für ein vorhandenes "Array von char" einen Index-Wert zurückliefern? Java Basics - Anfänger-Themen 3
G Methoden Methode die aus einem Array ein Index ausgibt? Java Basics - Anfänger-Themen 2
M Index of Array erweiteren Java Basics - Anfänger-Themen 24
L gerader Index im Array Java Basics - Anfänger-Themen 8
Z Array-Index einmalig je mit Random füllen Java Basics - Anfänger-Themen 7
M Kleinsten Index in Array finden Java Basics - Anfänger-Themen 6
E Arrayeintrag nach Index löschen und Array kürzen Java Basics - Anfänger-Themen 3
S Array - index von Benutzer eingegebenen char ausgeben Java Basics - Anfänger-Themen 3
MiMa Array mit ungültigen Index ansprechen Java Basics - Anfänger-Themen 2
F Fehler bei Array und Index Programmierung Java Basics - Anfänger-Themen 18
T Erste Schritte Java ein Array Feld[index] zurueckgeben? Java Basics - Anfänger-Themen 20
E Array bei Index ändern Java Basics - Anfänger-Themen 14
A dynamisches Array - Index Liste Java Basics - Anfänger-Themen 2
X Array Index Out of Bounds Java Basics - Anfänger-Themen 39
S Array bei index halbe umdrehen ohne hilfsfeld Java Basics - Anfänger-Themen 13
B Array mit Index 1 starten lassen Java Basics - Anfänger-Themen 5
P Array index per char suche auslesen Java Basics - Anfänger-Themen 3
J Array-Index nur als Integer möglich? Java Basics - Anfänger-Themen 15
H RemoteSocketAddress als Index von einem Array Java Basics - Anfänger-Themen 10
J Array - Index ermitteln per Wert Java Basics - Anfänger-Themen 3
E array index an methode übergeben? Java Basics - Anfänger-Themen 6
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
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
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
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

Ähnliche Java Themen

Neue Themen


Oben