Erste Schritte BinarySearchTree - Wo kommen die Werte her?

grueneneune

Mitglied
Hallo zusammen,

ich habe ein paar grundsätzliche Verständnisprobleme zum BinarySearchTree. Die unten angefügten Klassen sind mir dabei vorgegeben. Es geht mir lediglich darum, die gegebenen Methoden isEqual, isLess und isGreater zu überschreiben. Angedacht habe ich eine einfache Unterscheidung zwischen Zahlen, die - sofern sie größer als ihre Wurzel sind - rechts eingeordnet bzw. andernfalls links eingeordnet werden sollen. Dazu sollte eine einfache if-Abfrage reichen, die die Zahlen vergleicht (das Ganze natürlich auch nochmal für isLess und isEqual):

Java:
public boolean isGreater (Item pItem) {
     if (zahl1 > zahl2) {
           return true;
     } else {
           return false;
     }
}

Allerdings leuchtet mir nicht ein, wie ich diese Werte überhaupt in den Baum einschleuse und sie dann mit pItem vergleichen kann.
 

Anhänge

  • Item.java
    1,8 KB · Aufrufe: 19
  • BinaryTree.java
    5,6 KB · Aufrufe: 14
  • BinarySearchTree.java
    7,6 KB · Aufrufe: 14
S

SlaterB

Gast
fürs Einfügen ist BinarySearchTree, insert(Item pItem) zuständig,
da steht doch schon bisschen Code der vergleicht (mit anderen items!) und den Baum entlang wandert,
so in der Art gehts, was ist dazu die Frage?

edit:
ok, im Detail hapert es noch, die Unterscheidung zwischen weiter suchen und tatsächlich einfügen,
das findet man doch allgemein bei derartigen Implementationen im Netz,
oder bevor das jemand hier im Forum fertig codet oder beschreibt, erzähle du doch in Worten,
was da passieren soll, wie du das durch den Code auszudrücken gedenkst,
wie sieht ein Ablauf in einem Beispiel-Baum mit Einfügen von Beispiel-Wert X aus?


-----

bedenklich erscheint mir, dass BinarySearchTree eine Methode getLeftTree() genau wie BinaryTree,
das scheint mir bisschen doppelt gemoppelt, darüber schon nachgedacht und ist das nötig?

vielleicht das nur BinaryTree überlassen, der SearchTree nutzt diesen zum Durchlauf,
kann den BinaryTree zurückgeben, aber tut nicht selber so als hätte er auch Nachfolger
 
Zuletzt bearbeitet von einem Moderator:

grueneneune

Mitglied
Was mir einfach nicht einleuchten will, ist die Funktionsweise der abstrakten Klasse Item. Welchen Typ hat ein Objekt dieser Klasse und wie erzeuge ich solch ein Objekt? Wenn ich bspw. eine einfache int-Zahl in einen erstellten Baum einfügen will - geht das problemlos?

Dass die vorgegebenen Klassen verbesserungswürdig sind, ist gut möglich - jedoch soll ich anhand derer arbeiten.
 
S

SlaterB

Gast
Item ist abstrakt, quasi ein Interface, es muss erst Klassen geben die das implementieren, wenn dann werden sie es hoffentlich richtig machen, ob Integer, Bananen oder Deutschland-Flaggen, das kann dir komplett egal sein,
erzeugen musst du hier auch nicht, zum Test bietet sich aber natürlich eine Test-Klasse dafür dann,
mit Instanzattribut, z.B. Integer, und passenden Methoden, dann ganz normal Objekte davon erzeugen,


> if (zahl1 > zahl2) {
aus deinem Posting ist natürlich nicht so doll, eher
if (this.wert > pItem.wert) {

--------

für deinen Algorithmus ist das egal,
da musst du dich nur darauf verlassen/ hoffen, dass die Methoden im Fall der Fälle schon korrekt sein werden,
den Rest macht der Tree selber, fertig
 
Zuletzt bearbeitet von einem Moderator:

grueneneune

Mitglied
Entschuldigt die lange Abstinenz, mittlerweile habe ich es hinbekommen, dass Werte in den Baum eingefügt werden und mit inorder ausgegeben werden (funktioniert natürlich auch äquivalent mit preorder und postorder). Allerdings sind dabei zwei Teile drin, die ich so eher zusammenkopiert, als wirklich verstanden habe. Einmal Ausdrücke wie diesen hier:
Code:
((MeinIntegerItem)t.getItem()).getBetrag()
und generell die Nummer mit dem betrag. Es gibt z.B. eine Methode getBetrag, die nichts anderes macht als den betrag zurückzugeben. Wieso brauche ich dafür eine Methode und kann nicht direkt auf den Betrag zugreifen?

Wie dem aber auch sei, für meine mündliche Abiturprüfung (dafür war der Spaß gut) habe ich gewisse Teile einfach auswendig gelernt. Wollte aber niemand wissen - sind auch ohne Binärbaum 14 Punkte geworden (wenn man so eine Note seit der dritten Klasse nicht mehr gesehen hat, darf man das ruhig mal hinausposaunen!) :)

Java:
public class Test extends BinarySearchTree {
BinarySearchTree baum;
public Test() {
baum = new BinarySearchTree();
baum.insert(new MeinIntegerItem(5));
inorder(baum);
}

public void inorder(BinarySearchTree t) {
if(!t.isEmpty()) {
inorder(t.getLeftTree());
System.out.print(((MeinIntegerItem)t.getItem()).getBetrag() + " ");
inorder(t.getRightTree());
}
}

public class MeinIntegerItem extends Item {
int betrag;

public MeinIntegerItem(int pBetrag) {
betrag = pBetrag;
}

public boolean isEqual(Item item) {
if(betrag == ((MeinIntegerItem)item).getBetrag()) {
return true; 
} else {
return false;
}
}

public boolean isGreater(Item item) {
if(betrag > ((MeinIntegerItem)item).getBetrag()) {
return true; 
} else {
return false;
}
}

public boolean isLess(Item item) {
if(betrag < ((MeinIntegerItem)item).getBetrag()) {
return true; 
} else {
return false;
}
}

public int getBetrag() {
return betrag;
}
}
}

(Können noch Fehler drin sein, hab's jetzt nicht getestet.)
 
S

SlaterB

Gast
Kapslung ist ein riesiges Thema für sich
Datenkapselung (Programmierung) ? Wikipedia

zwei Punkte kurz angesprochen:
- Interface gehen eh nicht mit direkten Zugriff auf Attribute
- Vererbung oder auch nur interne Berechnung/ Umkonfiguration, lazy loading,
ein getter kann statt eines Attributs je nach Zustand auch erst aus der DB laden und noch viel verrückteres,

oft gibt es wirklich nur das Attribut, dann kann man es sich auch vorerst sparen, falls man nicht auf Symmerie achtet
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
A BinarySearchTree Java Basics - Anfänger-Themen 8
M Wie kommen diese Ausgaben zustande? Java Basics - Anfänger-Themen 12
G Welche Attribute kommen in den Konstruktor? Java Basics - Anfänger-Themen 5
D Beim Programmieren auf die Logisch einfache Lösung kommen. Java Basics - Anfänger-Themen 17
N Beim hochrechnen kommen garkeine/zuhohe zahlen raus Java Basics - Anfänger-Themen 6
E Senden von Objects an Client. Variablenwerte kommen nicht an Java Basics - Anfänger-Themen 5
A Beim txt Datei einlesen kommen zusätzliche Lehrzeichen dazu. Java Basics - Anfänger-Themen 5
M KeyEvents kommen nicht an Java Basics - Anfänger-Themen 16
T Von Millisekunden auf Stunden kommen Java Basics - Anfänger-Themen 2
G methodenvorschläge bei Punktnotation kommen nicht mehr !! (Eclipse) Java Basics - Anfänger-Themen 5
J Aus endlosschleife kommen Java Basics - Anfänger-Themen 5
K Befehl um am Anfang einer Methode zu kommen? Java Basics - Anfänger-Themen 9
R supermario problem (kommen nur zahlen raus) Java Basics - Anfänger-Themen 18
M Schreiben in eine Textdatei Daten kommen aus JTable Java Basics - Anfänger-Themen 2
F Wie kommen die Applets zum Client? Java Basics - Anfänger-Themen 7
M Variablen Werte nach setzen, bei Abfrage wieder alter Wert Java Basics - Anfänger-Themen 10
K Mehrere Werte in einem Switch Case parallel überprüfen Java Basics - Anfänger-Themen 23
F 2x 16bit Werte zu einem 32bit und dann splitten mit 0xb Java Basics - Anfänger-Themen 1
ptcho Werte/Position nach dem Funktionsaufruf tauschen? Java Basics - Anfänger-Themen 1
K Warum sind Werte in den Feldern ? Java Basics - Anfänger-Themen 2
S Bestimmte werte aus einem Array löschen Java Basics - Anfänger-Themen 2
javaBoon86 Arrays 2 Dimension Werte ausgeben Java Basics - Anfänger-Themen 15
E Reihenfolge der Werte umdrehen (mittels statischem int-Array Java Basics - Anfänger-Themen 3
N Einzelne Werte aus einem TreeSet auslesen Java Basics - Anfänger-Themen 2
TeacherMrSSimon Schachspiel, Werte in Figur eintragen klappt nicht Java Basics - Anfänger-Themen 23
TheSepp Nur Arrays ausgeben, die Werte zugewiesen haben. Java Basics - Anfänger-Themen 4
T ungeordnete Werte-Paare in einer Liste Java Basics - Anfänger-Themen 7
M Werte in Felder speichern und geordnet ausgeben Java Basics - Anfänger-Themen 8
R Methoden Werte einer ArrayList als Parameter übergeben. Java Basics - Anfänger-Themen 4
A CSv.Datei einlesen und die werte in zweidemosional Int Array speichern Java Basics - Anfänger-Themen 9
Jambolo Methode, welche die 3 letzten Parameter Werte speichert Java Basics - Anfänger-Themen 20
Chris.089 2 Werte im Array tauschen Java Basics - Anfänger-Themen 6
docmas 2DArray Werte werden nur untereinander ausgegeben Java Basics - Anfänger-Themen 1
M Nur int-Werte erlauben Java Basics - Anfänger-Themen 11
F Werte in einer Arraylist Zählen Java Basics - Anfänger-Themen 2
Fats Waller Compiler-Fehler Kann ich einen String und die Summe zweier Char Werte mittels der println Anweisung ausgeben Java Basics - Anfänger-Themen 4
P Doppelte werte in einer Liste zählen Java Basics - Anfänger-Themen 11
M Wie kann eine Methode eine andere Methode um Werte wie z.B. 1 erhöhen? Java Basics - Anfänger-Themen 6
Igig1 Wie lasse ich dir Werte in einem Array zusammenrücken? Java Basics - Anfänger-Themen 4
Igig1 Welche Werte sind als default Werte in einem Array, der als Datentyp eine Klasse hat? Java Basics - Anfänger-Themen 1
J Methoden Positive Werte zählen Java Basics - Anfänger-Themen 3
E Meine JCombobox werte an ohne selectiert zu haben Java Basics - Anfänger-Themen 6
H OOP Werte mit Set verändern Java Basics - Anfänger-Themen 6
W Werte durch Konsole einlesen Java Basics - Anfänger-Themen 10
H Welche Werte bei Objekterzeugung eingeben? Java Basics - Anfänger-Themen 2
M Von einem Menü Methode aus anderer Klasse ausführen, die errechnete Werte in Datei schreibt. Java Basics - Anfänger-Themen 8
sashady ursprüngliche Array-Werte bei erneutem Aufruf? Java Basics - Anfänger-Themen 7
cmn489 Werte beim Funktionsaufruf in ein Feld übertragen(falls dieses leer ist) Java Basics - Anfänger-Themen 1
E In Array Werte einfügen? Java Basics - Anfänger-Themen 5
HighLife Bestimmte Werte aus Array zählen Java Basics - Anfänger-Themen 15
L Methoden ArrayList Werte hinzufügen und löschen Java Basics - Anfänger-Themen 32
J Zufallszahlen generieren und Werte vergleichen Java Basics - Anfänger-Themen 3
M Wie kann ich Werte die in einer While Schleife sind weiter genutzt werden? Java Basics - Anfänger-Themen 7
L Werte von Objekte addieren Java Basics - Anfänger-Themen 14
R Werte und Reihenfolge in 2d Arrays vergleichen Java Basics - Anfänger-Themen 5
I Werte (u.a. Geldbeträge) in Datenbank speichern und Rundungen? Java Basics - Anfänger-Themen 8
eleonori Durchschnitt aller Werte eines Baums berechnen Java Basics - Anfänger-Themen 5
G Array Werte addieren Java Basics - Anfänger-Themen 4
J Methoden Frage: Array-Werte in anderer Methode ändern Java Basics - Anfänger-Themen 4
C Array-Werte werden gemischt, ohne Logik Java Basics - Anfänger-Themen 2
java3690 Java- liste füllen ud die werte addieren Java Basics - Anfänger-Themen 13
C Zufallszahl + Werte bereich einstellen Java Basics - Anfänger-Themen 2
J Alle Werte eines Strings zusammen addieren Java Basics - Anfänger-Themen 15
L 2 Dimensional Array werte überschreiben Java Basics - Anfänger-Themen 1
K Array alle Werte aufsummieren und ausgeben Java Basics - Anfänger-Themen 6
V Collections int Werte in einer Liste sortieren Java Basics - Anfänger-Themen 23
Rubberduck Combobox-Werte in GUI anzeigen Java Basics - Anfänger-Themen 13
J Neue Werte in ein Array hinzugeben Java Basics - Anfänger-Themen 8
L Wie frage ich ab, ob in einem Array, Werte doppelt vorkommen? Java Basics - Anfänger-Themen 4
A Negative float Werte? Java Basics - Anfänger-Themen 10
Kirby.exe Fehlende Int Werte aus Array mit streams finden Java Basics - Anfänger-Themen 19
Ellachen55 Wie nach häufigste Werte im Array suchen? Java Basics - Anfänger-Themen 2
D Input/Output Input von zwei Koordinaten validieren und anschließend Werte speichern Java Basics - Anfänger-Themen 7
F Variablen Werte einer Klasse überschreiben Java Basics - Anfänger-Themen 4
M Werte ändern sich nicht mehr nach Reset Java Basics - Anfänger-Themen 14
F Character umwandeln als Double Werte Java Basics - Anfänger-Themen 8
B Werte aus einem Unterprogramm in ein Array schreiben Java Basics - Anfänger-Themen 2
L Nur Bestimmte Werte aus einem Array in ein anderes Speichern Java Basics - Anfänger-Themen 11
C Ganzzahlige Werte in Boolean ausgeben und überprüfen ob Primzahl oder nicht, wenn es keine Primzahl ist soll es die Primfaktorzerlegung ausgeben Java Basics - Anfänger-Themen 4
S Werte aufsummieren in java? Java Basics - Anfänger-Themen 5
M Werte des Arrays addieren Java Basics - Anfänger-Themen 5
A Alle true Werte eines boolean Arrays herausfiltern Java Basics - Anfänger-Themen 19
C System.in.read() Boolsche Werte vergleichen Java Basics - Anfänger-Themen 8
M prüfen ob alle array werte gleich sind Java Basics - Anfänger-Themen 27
D Werte aus einem BinärBaum in einem Array speichern Java Basics - Anfänger-Themen 1
R Datenbank-Werte dynamisch ausgeben Java Basics - Anfänger-Themen 19
E Eigenschaften Werte, in einer anderen Klasse, zuweisen Java Basics - Anfänger-Themen 40
H Methoden Nutzung der Werte einer ausgeführten Objektmethode in anderen Objektmethoden Java Basics - Anfänger-Themen 2
O Map Werte Java Basics - Anfänger-Themen 2
dapzoo Compiler-Fehler Beim Werte verteilen in Objektarray NullPointerException Java Basics - Anfänger-Themen 4
L Werte zufällig aus Array zurückgeben Java Basics - Anfänger-Themen 15
B mehrere Werte mit scanner und while schleife einlesen, max berechnen bzw addieren Java Basics - Anfänger-Themen 2
S werte von objekten in schleife verändern Java Basics - Anfänger-Themen 14
R Vererbung werte von einem Objekt aus ein anderes übertragen Java Basics - Anfänger-Themen 7
D Datei auslesen & Werte in Variable speichern Java Basics - Anfänger-Themen 12
N Methoden HashMap interne Werte miteinander vergleichen Java Basics - Anfänger-Themen 7
L Bestimmte Werte eines Arrays ausgeben. Java Basics - Anfänger-Themen 3
Hanschyo String kann nicht Werte von Long annehmen Java Basics - Anfänger-Themen 2
A Sortieren ausgerechneter Werte aus einer TXT Datei Java Basics - Anfänger-Themen 8
S Werte in Klasse übergeben Java Basics - Anfänger-Themen 12

Ähnliche Java Themen

Neue Themen


Oben