Problem mit Ausgabe eines generischen Suchbaums

Status
Nicht offen für weitere Antworten.
Hallo,
Ich brauche wieder einmal Hilfe von den Profis ;)
Wir sollen in der akuellen Info-Übung einen generischen Suchbaum programmieren, da dann ein paar Daten (Strings) einfügen und wieder suchen und dabei die Zugriffe zählen.
Soweit sollte mein Programm schon ganz okay sein, die Methode insert funktioniert soweit denke ich.
Zum Testen habe ich noch eine Methode inorder(Suchbaum) geschrieben, die mir den Baum ausgeben soll (linker Sohn, Vater, rechter Sohn- halt inorder :D ). Leider bekomme ich als Ausgabe nur:
uebung11.Comparable@1ad086a
uebung11.Comparable@10385c1
, also die Adressen der Objekte.

Ich poste mal meine Dateien, vielleicht erkennt ihr ja sofort den Fehler bzw. könnt mir sagen, wie ich aus meinem Objekt, von dem ich ja weiß, dass es ein String is, den String bekomme :)

Haupt:
Java:
package uebung11;

public class Haupt {

	public static void inorder(Baum b){
		if(!b.empty())	{
			inorder(b.left());
			String s = new String(b.value().toString());
			System.out.println(s);
			inorder(b.rigth());
		}
	}
	
	
	public static void main(String[] args) {
		SecretsAndLies daten = new SecretsAndLies();
		Baum b = new Baum();
		
		b.insert(new Comparable(daten.getWord()));
		b.insert(new Comparable(daten.getWord()));
		inorder(b);
		

	}

}

Baum:
Java:
package uebung11;

public class Baum {
	Knoten wurzel;
	
	//KONSTRUKTOREN
	public Baum()	{
		//Erzeugt leeren Baum
		wurzel = null;
	}
	
	public Baum(Knoten k)	{
		//Erzeugt Baum mit nur Wurzel
		wurzel = k;
	}
	
	public Baum(Object x)	{
		//Erzeugt Baum mit nur Wurzel
		wurzel = new Knoten(x);
	}
	
	public Baum(Baum l, Object x, Baum r){
		//Erzeuge Baum aus 2 Baeumen und einem Object
		wurzel = new Knoten(x);
		
		if(l!=null)	{
			//Hänge den linken Baum an den linken Verweis von Wurzel
			wurzel.links = l.wurzel;
		}
		
		if(r!=null)	{
			//Hänge den rechten Baum an den rechten Verweis von Wurzel
			wurzel.rechts = r.wurzel;
		}
	}
	

	public boolean empty()	{
		//Testet ob Baum leer ist
		return (wurzel == null);
	}
	
	
	public Object value()	{
		//Gibt Wurzel zurueck
		if(!empty())	{
			return wurzel.inhalt;
		}	else	{
			//Baum ist leer
			return null;
		}
	}
	
	
	public Baum left()	{
		//Gibt den linken Teilbaum von Baum zurueck
		if(!empty())	{
			//Erzeugt neuen Baum aus dem Element "links unter der Wurzel" und gibt diesen zurueck
			return new Baum(wurzel.links);
		}	else	{
			//Baum ist leer
			return null;
		}
	}
	
	
	public Baum rigth()	{
		//Gibt den rechten Teilbaum von Baum zurueck
		if(!empty())	{
			//Erzeugt neuen Baum aus dem Element "rechts unter der Wurzel" und gibt diesen zurueck
			return new Baum(wurzel.rechts);
		}	else	{
			//Baum ist leer
			return null;
		}
	}
	
	
	public Comparable lookup(Comparable x)	{
		//Sucht nach x in dem Baum
		Knoten k = wurzel;
		
		while(k!=null)	{
			//Solange es "abwaerts geht im Baum"
			if(x.vergleicheMit((Comparable)k.inhalt) < 0)	{
				//x.inhalt ist kleiner als k.inhalt, also muss man nach links absteigen
				k = k.links;
			}	else	{
				if(x.vergleicheMit((Comparable)k.inhalt) > 0)	{
					//x.inhalt ist groesser als k.inhalt, also muss man nach rechts absteigen
					k = k.rechts;
				}	else	{
					//x.inhalt ist gleich k.inhalt, gib es zurueck
					return (Comparable) k.inhalt;
				}
			}
		}
		//x ist nicht in dem Baum
		return null;
	}
	
	
	public boolean insert(Comparable x)	{
		//Fuegt x in den Baum ein und gibt Erfolg als Boolean zurueck
		if(wurzel==null)	{
			//Baum ist leer, x wird als Wurzel eingefuegt
			wurzel = new Knoten(x);
			return true;
		}	else	{
			//Baum ist nicht leer
			Knoten vater = null;
			Knoten k = wurzel;
			
			while(k!=null)	{
				//Suche nach der Stelle, an der x eingefuegt werden muss
				vater = k;
				if(x.vergleicheMit((Comparable)k.inhalt) < 0)	{
					k = k.links;
				}	else	{
					if(x.vergleicheMit((Comparable)k.inhalt) > 0)	{
						k = k.rechts;
					}	else	{
						//Kann nicht einfuegen, da schon in Baum
						return false;
					}
				}
			}//ENDWHILE
			
			//Einfuegen von x
			if(x.vergleicheMit((Comparable)vater.inhalt) < 0)	{
				//x ist kleiner, muss also links eingefuegt werden
				vater.links = new Knoten(x);
			}	else	{
				//x muss rechts eingefuegt werden
				vater.rechts = new Knoten(x);
			}
			//Einfuegen erfolgreich
			return true;
		}//ENDE ELSE
	}
	
}

Knoten:
Java:
package uebung11;

public class Knoten {
	Knoten links;
	Knoten rechts;
	Object inhalt;
	
	public Knoten(Object x)	{
		inhalt = x;
		links = rechts = null;
	}
}

Comparable:
Java:
package uebung11;

public class Comparable {
	String inhalt;
	
	public Comparable(String x)	{
		inhalt = x;
	}
	
	public int vergleicheMit(Comparable x)	{
		return this.inhalt.compareTo(x.inhalt);
	}
}

... und zu guter letzt die vorgegebene SecretsandLies, die einem die Strings gibt:
Java:
package uebung11;

public class SecretsAndLies {
	private int counter, seed;
	private final int MAX_WORDS = 400; // Wie viele Worte werden benoetigt?
	private final int WORD_LENGTH = 8;

	/**
	 * Konstruktor
	 */
	public SecretsAndLies() {
		counter=0;
		seed=1;
	}

	/**
	 * Prueft, ob wir noch neue Worte haben
	 * @return
	 */
	public boolean wordsLeft(){
		return counter < MAX_WORDS;
	}
	
	/**
	 * Gibt eine skalierte Zufallszahl von 0..max-1 zurueck
	 * @param max
	 * @return
	 */
	private int rnd(int max)
	{
		seed = 51*seed + 1263;
		return Math.abs(seed)%max;
	}
	
	/**
	 * Gibt ein neues Wort zurueck
	 * @return
	 */
	public String getWord() {
		String word = "";
		for(int i = 0;i<WORD_LENGTH;i++)
			word += (char)(rnd((int)('Z'-'A'))+'A'+1);
		counter++;
		return word;
	}
	
	/**
	 * Setzt die Klasse auf Anfang zurueck
	 */
	public void reset(){
		counter=0;
		seed=1;
	}
	
	/**
	 * Beispiel zur Verwendung dieser Klasse
	 * @param args
	 */
/*	public static void main(String args[]) {
		SecretsAndLies kauderwelsch = new SecretsAndLies();
		System.out.println(kauderwelsch.getWord());
		while(kauderwelsch.wordsLeft())
			System.out.println(kauderwelsch.getWord());
	}*/
}

Habe an meiner inorder schon ne Menge rumgetrickst, bekomme aber halt immer die Adressen als Ausgabe oder die Fehlermeldung, dass casten von Object zu String nicht möglich ist. Will die Methode eigentlich ja auch nur als Kontrolle, dass mein Baum einwandfrei funktioniert, sonst kann ich mir da ja nich sicher sein ;)

DANKE schonmal für eure Hilfe :) :toll:
 

Painii

Bekanntes Mitglied
Also um das Problem mit dem casten zu "lösen":
Java:
//wie ich aus meinem Objekt, von dem ich ja weiß, dass es ein String is, den String bekomme?
if(objekt.getClass().equals(new String("").getClass())){
	myStringCast=(String) objekt;
	//System.out.println(myStringCast); -> ein String falls dein Objekt ein String ist, sonst geht er nicht ins if
}

Aber so allgemein generisch ist das ja nicht.

Generisch geht sehr schön in Java:
Java:
public class Baum<E>{ 
//Funktionen etc.
}
die du dann so zusammenbaust:
Java:
Baum<String> baum = new Baum<String>();
Vorteil: Java kann sicherstellen dass dann auch NUR String in den Baum kommen... und dein Cast wenn du was rausholst fällt weg.
Java:
String einString = baum.value(); //ohne cast möglich
 

HLX

Top Contributor
Du kannst in der Klasse Comparable die Methode toString überschreiben:
Java:
public String toString() {
     return inhalt;
}
 
Status
Nicht offen für weitere Antworten.
Ähnliche Java Themen
  Titel Forum Antworten Datum
M Problem bei Ausgabe eines Arrays Java Basics - Anfänger-Themen 5
V Vorstellung und Problem bei Ausgabe des Inhalts eines Arrays Java Basics - Anfänger-Themen 4
nelsonmandela Problem bei Ausgabe einer Switch - Case Funktion Java Basics - Anfänger-Themen 5
Kalibru Problem bei Ausgabe von Objekt Java Basics - Anfänger-Themen 1
M Problem bei Ausgabe Java Basics - Anfänger-Themen 7
G Problem bei der Ausgabe einer Main Claase Java Basics - Anfänger-Themen 7
S Doppel For Schleife mit Arrays - Problem bei der Ausgabe Java Basics - Anfänger-Themen 4
A Problem mit Array Ausgabe Java Basics - Anfänger-Themen 7
L 2 dimensionales Array, Problem der Ausgabe Java Basics - Anfänger-Themen 4
P Input/Output Problem bei Ausgabe von Arraylist Java Basics - Anfänger-Themen 6
M Problem mit Methoden Ausgabe Java Basics - Anfänger-Themen 17
H Ausgabe Problem Java Basics - Anfänger-Themen 2
P Matrizenrechnung Problem mit Ausgabe Java Basics - Anfänger-Themen 8
S Erste Schritte Kleine Problem mit Ausgabe in eine Datei Java Basics - Anfänger-Themen 11
N Input/Output Schleifen - Ausgabe Problem Java Basics - Anfänger-Themen 2
P Input/Output Eingabe/Ausgabe Problem Java Basics - Anfänger-Themen 2
B Ausgabe problem in Funktionen Java Basics - Anfänger-Themen 6
K Problem bei Ausgabe mit println Java Basics - Anfänger-Themen 19
N Ausgabe Problem System.console().printf() Java Basics - Anfänger-Themen 6
E Tankbeleg - Problem mit Ausgabe Java Basics - Anfänger-Themen 5
JeromeM90 Problem bei einer Ausgabe von einem bestimmten Zeichen Java Basics - Anfänger-Themen 5
M Problem mit meiner Ausgabe :-( Java Basics - Anfänger-Themen 3
S Ausgabe auf der Java-Console (Java Problem) Java Basics - Anfänger-Themen 13
K Ausgabe problem in einer Hausaufgabe Java Basics - Anfänger-Themen 5
R Problem bei Ausgabe von Unicode-Zeichen Java Basics - Anfänger-Themen 6
G ausgabe Problem Java Basics - Anfänger-Themen 9
A Problem mit Ausgabe einer Liste über einen Client Java Basics - Anfänger-Themen 5
V ganz kurzes kskb mit Problem - keine Ausgabe Java Basics - Anfänger-Themen 2
M problem mit der ausgabe Java Basics - Anfänger-Themen 2
W Problem mit iReport: Keine Ausgabe Java Basics - Anfänger-Themen 9
Z Problem mit Schleife und korrekter Ausgabe: Java Basics - Anfänger-Themen 13
C Matrix: problem mit der Ausgabe Java Basics - Anfänger-Themen 6
E Problem bei Ausgabe von Feldern und Methoden! Java Basics - Anfänger-Themen 2
G Problem mit Ausgabe von Text. Zeilenabbruch. Java Basics - Anfänger-Themen 4
N Ausgabe-Problem Java Basics - Anfänger-Themen 3
R Best Practice Problem mit (einfacher) Doppelt-Schleife Java Basics - Anfänger-Themen 53
K Verständnis Problem bei Server/Client Java Basics - Anfänger-Themen 2
I WildFily - unterschiedliche Libs im Projekt verursachen Problem Java Basics - Anfänger-Themen 11
imocode Vererbung Problem mit Vererbung Java Basics - Anfänger-Themen 2
L Taschenrechner Problem Java Basics - Anfänger-Themen 4
I Applikationsserver (WildFly) - Zugriff auf Ressourcen.. Problem mit Pfade Java Basics - Anfänger-Themen 10
A ScheduledExecutorService problem Java Basics - Anfänger-Themen 7
marcelnedza Problem mit Weltzuweisung, JavaKarol Java Basics - Anfänger-Themen 13
XWing Methoden rückgabe Problem? Java Basics - Anfänger-Themen 6
M Erste Schritte Collatz Problem max int Java Basics - Anfänger-Themen 3
M Problem bei verschachtelter for-Schleife bei zweidimensionalen Arrays Java Basics - Anfänger-Themen 3
C GLOOP Problem beim Erstellen der Kamera Java Basics - Anfänger-Themen 9
frager2345 Problem mit Methode Java Basics - Anfänger-Themen 4
L Problem bei Rechnung mit Math.pow Java Basics - Anfänger-Themen 13
A Thread-Schreibe-Lese-Problem Java Basics - Anfänger-Themen 4
SUPERTJB return Problem Java Basics - Anfänger-Themen 3
sserio BigInteger Problem Java Basics - Anfänger-Themen 4
JordenJost Taschenrechner problem Java Basics - Anfänger-Themen 5
K Problem mit "Random" Java Basics - Anfänger-Themen 5
S Datei anlegen Problem! Groß- und Kleinschreibung wird nicht unterschieden Java Basics - Anfänger-Themen 4
sserio Problem beim Anzeigen Java Basics - Anfänger-Themen 5
xanxk Problem For-Schleife mit Charakter Java Basics - Anfänger-Themen 2
L Unbekanntes Problem mit 2d Array Java Basics - Anfänger-Themen 6
sserio Liste erstellt und ein Problem mit dem Index Java Basics - Anfänger-Themen 8
sserio Schwimmen als Spiel. Problem mit to String/ generate a card Java Basics - Anfänger-Themen 4
J Schleife Problem Java Basics - Anfänger-Themen 2
D Problem mit der Erkennung von \n Java Basics - Anfänger-Themen 2
milan123 das ist meine aufgabe ich hab das problem das bei mir Wenn ich die Richtung der Linien verändern will und drei davon sind richtig, verändere ich die 4 Java Basics - Anfänger-Themen 3
M Verständins Problem bei Aufgabe Java Basics - Anfänger-Themen 4
HeiTim Problem mit der Kommasetzung an der richtigen stelle Java Basics - Anfänger-Themen 59
Temsky34 Problem mit dem Code Java Basics - Anfänger-Themen 17
P Problem mit Calendar.getDisplayName() Java Basics - Anfänger-Themen 8
C Problem mit mehreren Methoden + Scanner Java Basics - Anfänger-Themen 5
P Datei einlesen, nach Begriff filtern und in Datei ausgeben. Problem Standardausgabe über Konsole Java Basics - Anfänger-Themen 19
M Problem mit Klassenverständnis und Button Java Basics - Anfänger-Themen 8
EchtKeineAhnungManchmal hallo habe ein Problem mit einer Datei -> (Zugriff verweigert) Java Basics - Anfänger-Themen 4
H Problem mit Verzweigungen Java Basics - Anfänger-Themen 6
H Problem mit Rückgabewert Java Basics - Anfänger-Themen 7
josfe1234 JAVA FX problem Java Basics - Anfänger-Themen 3
A Code Problem Java Basics - Anfänger-Themen 6
Henri Problem von Typen Java Basics - Anfänger-Themen 7
J Problem mit "ArrayIndexOutOfBoundsException" Java Basics - Anfänger-Themen 11
K jackson Mapping - Problem mit Zeitzonen Java Basics - Anfänger-Themen 10
B Threads Problem mit mehreren Threads Java Basics - Anfänger-Themen 38
I Output BigDecimal anstatt double / Problem beim Rechnen Java Basics - Anfänger-Themen 16
D Schleifen Problem Java Basics - Anfänger-Themen 2
H So viele Fehlermeldungen, dass ich nicht weiß wo das Problem ist. Java Basics - Anfänger-Themen 6
J JAVA-Problem blockiert MEDIATHEKVIEW Java Basics - Anfänger-Themen 13
T Problem mit Lehrzeichen und String bei einfacher Chiffre Java Basics - Anfänger-Themen 8
J extends Problem Java Basics - Anfänger-Themen 2
C Polymorphie-Problem Java Basics - Anfänger-Themen 3
I Format Problem mit Wert - bekomme 0,10 anstatt 10,00 Java Basics - Anfänger-Themen 6
J Problem mit einer Methode die gewissen Inhalt einer Array löschen soll Java Basics - Anfänger-Themen 9
J Problem mit einer Methode, die beliebig viele Objekte in Array speichern soll Java Basics - Anfänger-Themen 6
J Allgemeines Problem mit Klassen Java Basics - Anfänger-Themen 5
U Problem mit dem initialisieren meines Strings in einer Schleife Java Basics - Anfänger-Themen 5
amgadalghabra algorithmisches Problem Java Basics - Anfänger-Themen 19
J Traveling Salesman Problem [Arrays] Java Basics - Anfänger-Themen 9
R ArrayList Problem Java Basics - Anfänger-Themen 6
InfinityDE Problem mit Datenübergabe an Konstruktor Java Basics - Anfänger-Themen 7
C RegEx Problem Java Basics - Anfänger-Themen 4
J Anfänger TicTacToe, Problem bei Gewinnoption, sowohl Unentschieden Java Basics - Anfänger-Themen 8
E Taschenrechner GUI Problem mit Fehlerhandling Java Basics - Anfänger-Themen 6
M Input/Output Fallunterscheidung Problem Java Basics - Anfänger-Themen 17
P Problem beim Überschreiben einer vererbten Methode Java Basics - Anfänger-Themen 4

Ähnliche Java Themen

Neue Themen


Oben