Bäume in Java. Knoten in Array speichern

Status
Nicht offen für weitere Antworten.
C

Christian1986

Gast
Hallo, ich habe hier den Quellcode zu einem Programm, mit dem man Bäume erstellen kann und damit dann einiges machen kann.

Mit
BinTree t = new BinTree();
erstellt man den neuen baum t.


Mit
ZahlNode n16 = new ZahlNode(16);
einen neuen Knoten 16

Das angehängte beispiel funktioniert problemlos, d.h. es wird der Baum erzeugt der in der Main Klasse (haq) angegeben ist.
Erst beim Anwenden der Methode toArray, wo also der Baum in ein Array geladen wird, gibt es Probleme. Also genau gesagt nach dem Einfügen der Zeile

toArray(t);


Die Methode als solche funktioniert, nur was mache ich beim Aufruf falsch?

Danke!!


Code:
public class haq {

	/**
	 * @param args
	 */
	public static void main(String[] args) {
		 //Erstelle eine Klasse, die einen Baum übergeben bekommt
		// und ihn in einer Liste abspeichert
		ConsList liste = new ConsList();

		liste.append("Hallo");
		BinTree t = new BinTree();
		ZahlNode n16 = new ZahlNode(16);
		ZahlNode n8 = new ZahlNode(8);
		ZahlNode n4 = new ZahlNode(4);
		ZahlNode n12 = new ZahlNode(12);
		ZahlNode n24 = new ZahlNode(24);
		ZahlNode n20 = new ZahlNode(20);
		ZahlNode n28 = new ZahlNode(28);
		t.root=n16;
		n16.left=n8;
		n16.right=n24;
		
		n8.right=n12;
		n8.left=n4;
		
		n24.left=n20;
		n24.right=n28;
		
	toArray(t);
	 
		 
	}

}




public class ZahlNode {
	// das Objekt, welches dem Knoten zugeordnet ist
	public int z; 
	// die beiden Kindknoten
	public ZahlNode left;
    public ZahlNode right;
	public ZahlNode(int z) {
		this.z = z;
		left = right = null;
	}
}



public class BinTree
{
	public ZahlNode root; // der Wurzelknoten
	public BinTree() { root = null; /* leerer Baum */ }
	public boolean contains(int z) { return contains(root, z); }
	protected boolean contains(ZahlNode node, int z) {
		if (node == null) return false;
		if (node.z == z) return true;
		return contains(node.left, z) 
		    || contains(node.right, z);
	}
	public void preorder() { 
		preorder(root); 
		System.out.println();
	}
	public void preorder(ZahlNode node) {
		if (node == null) return ;
		do_something(node.z);
		preorder(node.left);
		preorder(node.right);
	}
	public void inorder() { 
		inorder(root); 
		System.out.println();
	}
	public void inorder(ZahlNode node) {
		if (node == null) return ;
		inorder(node.left);
		do_something(node.z);
		inorder(node.right);
	}
	public void postorder() { 
		postorder(root); 
		System.out.println();
	}
	public void postorder(ZahlNode node) {
		if (node == null) return ;
		postorder(node.left);
		postorder(node.right);
		do_something(node.z);
	}
//	public void bfs() {
//		ConsList L = new ConsList();
//		L.append(root); // Beginne bei Wurzelknoten
//		while (!L.isEmpty()) {// Solange es noch zu besuchende Knoten gibt..
//			Node node = (Node)L.removeHead();
//			do_something(node.obj); 		// besuche naechsten Knoten ..
//			if (node.left != null) 	// und markiere seinen ..
//				L.append(node.left); // linken Kindknoten ..
//			if (node.right != null) 	// und seinen ..
//				L.append(node.right);	// rechten Kindknoten 
//		}
//	}
	
	
	
	public void do_something(int z) {
		System.out.print(z + " ");
	}

	public int getNumNodes() {
		return getNumNodes(root);
	}
	
	public int[] toArray(BinTree tree){
		int numnodes = tree.getNumNodes();
		int[] array = new int[numnodes];
		int i=0;

		//von oben bfs()
		ConsList L = new ConsList();
		L.append(root); // Beginne bei Wurzelknoten
		while (!L.isEmpty()) {// Solange es noch zu besuchende Knoten gibt..
			ZahlNode node = (ZahlNode)L.removeHead();

			array[i] = node.z;
			i++;
			if (node.left != null) 	// und markiere seinen ..
				L.append(node.left); // linken Kindknoten ..
			if (node.right != null) 	// und seinen ..
				L.append(node.right);	// rechten Kindknoten
		}
		return array;
	}
	
	protected int getNumNodes(ZahlNode node) {
		if (node == null) return 0;
		return 1 + getNumNodes(node.left) + getNumNodes(node.right);
	}

	public int getHeight() {
		return getHeight(root);
	}
	protected int getHeight(ZahlNode node) {
		if (node == null) return 0;
		if (node.left == null && node.right == null) return 0;
		return 1 + Math.max(getHeight(node.left), getHeight(node.right));
	}

	 
}
 
C

Christian1986

Gast
Die Fehlermeldung ist übrigens

Exception in thread "main" java.lang.Error: Unresolved compilation problem:
The method toArray(BinTree) is undefined for the type haq

at haq.main(haq.java:31)
 
G

Gast

Gast
mit dem Aufruf

BinTree.toArray(t);

klappts aber auch nicht. Wie würdet ihr das denn machen?
 
Status
Nicht offen für weitere Antworten.
Ähnliche Java Themen
  Titel Forum Antworten Datum
G Rot-Schwarz-Bäume Java Java Basics - Anfänger-Themen 10
C Bäume in Java. Code funktioniert nicht Java Basics - Anfänger-Themen 12
F Bäume in Java Java Basics - Anfänger-Themen 4
P Bäume Java Basics - Anfänger-Themen 13
Cassy3 Binäre Bäume Rekursiv durchlaufen und bestimmte Elemente Zählen Java Basics - Anfänger-Themen 6
E Bäume/ allgemeine Fragen Java Basics - Anfänger-Themen 21
M Rot Schwarz Bäume, ausführen? Java Basics - Anfänger-Themen 6
L Binären Bäume für beliebige Datentypen Java Basics - Anfänger-Themen 15
B Theorie Rot-Schwarz-Bäume Java Basics - Anfänger-Themen 2
D Klausur Vorbereitung: Listen, Rekursion, Bäume & Vererbung Java Basics - Anfänger-Themen 3
M Bäume und Listener Java Basics - Anfänger-Themen 2
L 2-3-4 Bäume Konstruktor Java Basics - Anfänger-Themen 2
E Binäre Bäume Java Basics - Anfänger-Themen 7
W Bäume - containsValueRec Java Basics - Anfänger-Themen 2
R Crashkurs Listen / Bäume Java Basics - Anfänger-Themen 10
J bäume Java Basics - Anfänger-Themen 5
G Tertiäre Bäume Java Basics - Anfänger-Themen 2
G Bäume implementieren Java Basics - Anfänger-Themen 7
F Bäume zeichnen Java Basics - Anfänger-Themen 5
D n-näre Bäume (DOM) durchsuchen Java Basics - Anfänger-Themen 4
G Frage zur Bäume ? Java Basics - Anfänger-Themen 3
L [Aufgabe] Huffman Bäume Java Basics - Anfänger-Themen 10
H .java Dateien in Eclipse einbinden und ausführen Java Basics - Anfänger-Themen 1
onlyxlia Schlüsselworte Was meint man mit "einen Typ" in Java erstellen? Java Basics - Anfänger-Themen 2
O Java Kara geschweifte Klammern Java Basics - Anfänger-Themen 2
richis-fragen Mausrad logitech kann links und rechts klick wie in java abragen. Java Basics - Anfänger-Themen 15
XWing Java Klssenproblem Java Basics - Anfänger-Themen 4
R Umgebungsvariable java -cp gibt immer Java-Hilfe... Java Basics - Anfänger-Themen 3
farbenlos Csv Datei in Java einlesen Java Basics - Anfänger-Themen 18
F TableModelListener: java.lang.ArrayIndexOutOfBoundsException: 132 Java Basics - Anfänger-Themen 3
G Java 8 - Support-Ende Java Basics - Anfänger-Themen 7
T Java Weihnachtsbaum + Rahmen Java Basics - Anfänger-Themen 1
N Will mit Java anfangen Java Basics - Anfänger-Themen 13
Ü Java Array - Buchstaben als Zahlen ausgeben Java Basics - Anfänger-Themen 22
M Java Iterator Verständnisfrage Java Basics - Anfänger-Themen 6
M Java Mail Programm Java Basics - Anfänger-Themen 4
Sniper1000 Java 391 für Windows Java Basics - Anfänger-Themen 37
J Java long- in int-Variable umwandeln Java Basics - Anfänger-Themen 6
JaZuDemNo Java im Studium Java Basics - Anfänger-Themen 7
E Java Programm zur anzeige, ob Winter- oder Sommerzeit herrscht Java Basics - Anfänger-Themen 62
I QR code in Java selber generieren Java Basics - Anfänger-Themen 5
V Java-Ausnahmebehandlung: Behandlung geprüfter Ausnahmen Java Basics - Anfänger-Themen 1
krgewb Java Streams Java Basics - Anfänger-Themen 10
A Überwältigt von der komplexen Java Welt Java Basics - Anfänger-Themen 29
O Mehrfachvererbung auf Spezifikations- und Implementierungsebene in Java. Interfaces Java Basics - Anfänger-Themen 19
John_Sace Homogene Realisierung von Generics in Java ? Java Basics - Anfänger-Themen 19
P Meldung aus Java-Klasse in Thread an aufrufende Klasse Java Basics - Anfänger-Themen 1
R mit Java API arbeiten Java Basics - Anfänger-Themen 9
P JDK installieren Probleme bei der Java-Installation Java Basics - Anfänger-Themen 8
S Java: Wie sortiere ich eine ArrayList benutzerdefinierter Objekte nach einem bestimmten Attribut? Java Basics - Anfänger-Themen 2
Timo12345 JNLP File mit Java öffnen Java Basics - Anfänger-Themen 2
S Video Editierung mit Java.._ Java Basics - Anfänger-Themen 2
F Einstelungen in Java - CursorBlinkRate Java Basics - Anfänger-Themen 10
A PHP $_POST["name"] in Java Java Basics - Anfänger-Themen 3
vivansai21 Is there a oneliner to create a SortedSet filled with one or multiple elements in Java? Java Basics - Anfänger-Themen 9
Athro-Hiro Weißes Bild in Java erstellen Java Basics - Anfänger-Themen 3
Arjunreddy Can someone please tell me how to use a debugger in BlueJ(a Java environment) Java Basics - Anfänger-Themen 1
M Java assoziationen (UML) Java Basics - Anfänger-Themen 8
H Excel-Tabellen mit Java erstellen Java Basics - Anfänger-Themen 4
Simon16 Java ArrayListe von einer Klasse sortieren Java Basics - Anfänger-Themen 2
P Wie kann ich in meinem Java Programm etwas dauerhaft speichern? Java Basics - Anfänger-Themen 5
H Nutzt Eclipse alle CPU-Threads beim Ausführen von Java-Programmen? Java Basics - Anfänger-Themen 4
xXGrowGuruXx Java einstieg, leichte sache 0 verstanden Java Basics - Anfänger-Themen 7
A java.sql.SQLException: Data type mismatch. Java Basics - Anfänger-Themen 1
H Java-Programm zur Ausgabe von Zuständen Java Basics - Anfänger-Themen 80
N Java Spiel Figur auf dem Hintergrundbild bewegen. Java Basics - Anfänger-Themen 11
G Kann Java-Programm nicht als jar aufrufen, auch als EXE nicht Java Basics - Anfänger-Themen 19
N Java Taschenrechner hat Jemand vlt einen Tipp dafür wie ich jetzt die buttons verbinden kann und das Ergebnis auf dem textfield anzeigen lassen kann Java Basics - Anfänger-Themen 13
A Lerngruppe Java Java Basics - Anfänger-Themen 2
G Help me in the Java Program Java Basics - Anfänger-Themen 2
L Java- Vererbung Java Basics - Anfänger-Themen 4
LimDul Suche Java Stream Tutorial Java Basics - Anfänger-Themen 2
_so_far_away_ Ich möchte Java lernen Java Basics - Anfänger-Themen 11
benny1993 Java Programm erstellen für ein Fußball-Turnier Java Basics - Anfänger-Themen 3
M Datentypen While-Schleife eine Java Methode erstellen Java Basics - Anfänger-Themen 3
V Bild per Java Script austauschen Java Basics - Anfänger-Themen 7
MoxMorris this Keyword in Java Java Basics - Anfänger-Themen 14
D Wie kann man in Java nach Arrays auf Duplikate prüfen Java Basics - Anfänger-Themen 12
wolei JAVA Zeitdifferenz feststellen. Java Basics - Anfänger-Themen 4
DiyarcanZeren Rekursion in Java Java Basics - Anfänger-Themen 5
wolei Java generic interface in a generic class Java Basics - Anfänger-Themen 6
monsterherz Ablauf der Erstellung eines Java Programmes Java Basics - Anfänger-Themen 17
monsterherz Circle.java:5: error: <identifier> expected Java Basics - Anfänger-Themen 2
julian-fr Wie kann ich am besten Java lernen? Java Basics - Anfänger-Themen 17
A Java-Properties und -RessourceBundles Java Basics - Anfänger-Themen 5
lrnz22 Java-Basics-Aufgabe Java Basics - Anfänger-Themen 8
R Java kann nicht installiert werden Java Basics - Anfänger-Themen 8
marcelnedza Finde meinen Fehler in einer Methode nicht, Java Karol Java Basics - Anfänger-Themen 15
G In ein java Dokument Ton einbinden Java Basics - Anfänger-Themen 1
C was heisst es wenn java ']' erwartet ? Java Basics - Anfänger-Themen 2
KeinJavaFreak Erste Schritte Programm "Java(TM) Platform SE binary " nicht vorhanden Java Basics - Anfänger-Themen 1
KeinJavaFreak Erste Schritte Java "Executable Jar File" nicht vorhanden Java Basics - Anfänger-Themen 1
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
J Java Testklasse Java Basics - Anfänger-Themen 5
P Java Selenium . Parameterized.Parameters erzeugt eine Fehlermeldung Java Basics - Anfänger-Themen 14
W Java-Code mit Array Java Basics - Anfänger-Themen 14
W Java-Code Java Basics - Anfänger-Themen 2
P BeforeEach AfterEach werden nicht ausgeführt. Java / Selenium Java Basics - Anfänger-Themen 4
A Wie führe ich eine Batch-Datei von meiner Java-Anwendung aus? Java Basics - Anfänger-Themen 18

Ähnliche Java Themen

Neue Themen


Oben