Variable Parameterliste in Binärbaum

Sweetsister

Mitglied
Hi :)

ich habe ein großes Verständnisproblem und hoffe, dass vielleicht hier jemand Zeit und Geduld hat, mir da weiterzuhelfen. Ich weiß einfach auch nicht, wen ich fragen soll:(

Wir haben eine Ü-Aufgabe, und zwar sollen wir einen binären Suchbaum programmieren in Java. Dazu sollen wir variable Parameterlisten verwenden, um mehrere Elemente einzufügen bzw. zu löschen.

Nun bin ich natürlich erstmal auf die Suche im Internet gegangen, um variable Parameterlisten zu verstehen. In der Aufgabe gab es ein kleines Bsp:

[Java] int addiere (int... summanden){
int summe=0;
for(int i = 0; i<summanden.length;i++){
summe+=summanden;
return summe;
}
[/Java]

Das hab ich auch verstanden und damit ein wenig rumgespielt im Editor. Das geht gut.

Dann habe ich natürlich nach Bäumen gesucht. Wie Bäume aussehen, das weiß ich und ich kam auch selbst auf den Gedanken, dass die Knoten aus einer Klasse abgeleitet werden müssen.

Aber mir ist der Code nicht so klar. Und wenn ich bisher gedacht hab, dass ich Java+OO verstanden hab, werde ich gerade eines Besseren belehrt:noe:

[Java]
class Knoten{
int wert;
Knoten links;
Knoten rechts;
}
[/Java]

Also die Instanzvariable wert ist klar (wobei ich mich frage, ob das so bleibt, auch wenn ich eine Parameterliste auslese). Aber wie stelle ich mir Knoten links, Knoten rechts vor? Ich hadere gerade daran, sind das schon zwei Instanzen? Also Vorangekündigte? Es sollen Referenzen sein, aber wir haben bisher immer die Boxnotation genutzt und da weiß ich nicht, wie ich mir das bildlich vorstellen soll?!

Und ich merke auch, dass mir der Sinn der Konstruktoren nicht ganz klar ist. Es werden in allen Beispielen, die ich gefunden habe, Konstruktoren benutzt. Aber warum ist das sinnvoll?

Das klingt so nach doofen Fragen, aber ich bin einfach nicht lang genug mit Java unterwegs, um mir das erklären zu können.

Kann mir jemand dabei helfen?

Danke und viele Grüße
Sandra
 

ne0n2005

Mitglied
Hallo,
also jeder Knoten eines binären Baumes hat einen Wert und einen, zwei oder keinen Nachfolger. Knoten links und Knoten rechts sind halt wieder eigenständige Knoten, welche nur Informationen über ihre Nachfolger und nicht über ihren Vorgänger haben.
Die Konstruktoren, welche du angesprochen hast sind dann vermutlich jede, die den rechten und linken Knoten setzen.
Durchsuchen kann man dann einen solchen binären Baum am besten mithile der Rekursion, weil jeder Knoten selbst auch Teilbaum ist. Zur ausgabe von binär Bäumen wären Stichwörter dann: preorder, inorder und postorder.
Und bei der Modelierung des b. Baumes kannst du die Tatsache das zu dann später variable Parameterlisten benutzen sollst ruhig erstmal vernachlässigen.

edit: jedoch finde ich die aufgabe Aufgabe einen komplett funktionierenden binären Baum in Java zu implementieren schon etwas komisch. Ich möchte mal behaupten, dass es der Anweisung nahe kommt sich intensiv mit Bäumen zu beschäftigen. Und die einen schreiben dann eben Code ab ohne ihn zu verstehen und die anderen verstehen lieber was sie da schreiben. Denn alleine kommt da sicher keiner drauf wie das funktioniert; außer er hat es geschafft zu verstehen die die Rekursion funktioniert, ohne das jemanls an dem Beipsiel des b. Baumes gesheen zu haben. (Ich wollt mal was gesagt haben und dich vielleicht auch gewisserweise trösten, wenn du nicht alles verstehst was du da siehst^^)
 
Zuletzt bearbeitet:

Michael...

Top Contributor
[Java]
class Knoten{
int wert;
Knoten links;
Knoten rechts;
}
[/Java]

Also die Instanzvariable wert ist klar (wobei ich mich frage, ob das so bleibt, auch wenn ich eine Parameterliste auslese). Aber wie stelle ich mir Knoten links, Knoten rechts vor? Ich hadere gerade daran, sind das schon zwei Instanzen? Also Vorangekündigte? Es sollen Referenzen sein, aber wir haben bisher immer die Boxnotation genutzt und da weiß ich nicht, wie ich mir das bildlich vorstellen soll?!
Knoten rechts und links sind Instanzvariablen vom Typ Knoten ;-) damit kann ein Knoten Referenzen auf seinen rechten und linken Knoten halten, diese müssen nicht initialiesiert sein, wenn ein Knoten keinen rechten und/oder linken Kindknoten besitzt.

Und ich merke auch, dass mir der Sinn der Konstruktoren nicht ganz klar ist. Es werden in allen Beispielen, die ich gefunden habe, Konstruktoren benutzt. Aber warum ist das sinnvoll?
Konstruktoren sind "Methoden" die beim Erzeugen einer Instanz einer Klasse aufgerufen werden, darin werden je nach Komplexität der Klasse z.B. Attribute initialisiert. Jede Klasse hat mindestens einen Konstruktor - auch wenn er nicht immer explizit implementiert wurde.
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
M Länge eines Arrays als Variable speichern möglich? Java Basics - Anfänger-Themen 14
R Liste in Variable speichern Java Basics - Anfänger-Themen 6
J Java long- in int-Variable umwandeln Java Basics - Anfänger-Themen 6
Nitrogames Variablen Variable aus JOptionPane Abfrage in Array einfügen Java Basics - Anfänger-Themen 4
E Variable von 1. Fenster an 2. Fenster übergeben. Java Basics - Anfänger-Themen 7
T Variable in Schleife deklarieren, Speicherplatz, Garbage Collector Java Basics - Anfänger-Themen 10
T Datum als Variable wert Java Basics - Anfänger-Themen 4
G Variable aktualisiert sich nicht in rekursiver Methode Java Basics - Anfänger-Themen 4
R Compiler-Fehler Variable wird nicht gefunden bzw. erkannt? Java Basics - Anfänger-Themen 2
Say super.methode / super.variable und super(variable) Java Basics - Anfänger-Themen 2
M variable in anderer funktion aufrufen Java Basics - Anfänger-Themen 10
N Was Passiert mit dem Namen einer Variable, wenn man diese einer Liste Hinzufügt Java Basics - Anfänger-Themen 16
T Variable von Objekten in einer Methode überprüfen Java Basics - Anfänger-Themen 26
U Wie mache ich die Variable xyz eindeutig/unique? Java Basics - Anfänger-Themen 20
JordenJost char variable funktioniert irgendwie nicht a+b ergibt nicht à Java Basics - Anfänger-Themen 4
M Variable Felderanzahl Java Java Basics - Anfänger-Themen 10
T Variable durch Action Listener ändern Java Basics - Anfänger-Themen 2
stormyark Fehler beim überschreiben einer Variable Java Basics - Anfänger-Themen 1
P Zähler Variable für mehrere Objekte Java Basics - Anfänger-Themen 6
S Eine Variable in einem Array speichern Java Basics - Anfänger-Themen 5
I Methoden Wieso wird mein Array "a" verändert und meine Variable "a" nicht? Java Basics - Anfänger-Themen 4
M Variable in einer Schleife initialisieren Java Basics - Anfänger-Themen 46
W Schleife und einmal variable++ zu viel Java Basics - Anfänger-Themen 20
M String mit Variable vergleichen Java Basics - Anfänger-Themen 9
M Methoden Wert einer Variable geht verloren? Java Basics - Anfänger-Themen 6
G variable kopieren bzw. woanders benutzen Java Basics - Anfänger-Themen 6
Ameise04 Variablen Inhalt einer Variable im Code verwenden? Java Basics - Anfänger-Themen 9
J Double Variable und Addition Java Basics - Anfänger-Themen 2
I Variable innerhalb Methode: Local variable test defined in an enclosing scope must be final or effectively final Java Basics - Anfänger-Themen 3
KogoroMori21 Variable im Parameter und Ohne Java Basics - Anfänger-Themen 5
Vivien Auf eine Variable von einer anderen Klasse aus zugreifen Java Basics - Anfänger-Themen 3
H Datentypen Wertebereich von <Klassenname> <Variable> Java Basics - Anfänger-Themen 12
M Private Variable Java Basics - Anfänger-Themen 2
idontknow707 Matrix nach z.B. Variable durchsuchen Java Basics - Anfänger-Themen 4
T Variable in for Schleife ansprechen ohne Array ? Java Basics - Anfänger-Themen 25
s.marcii Modulo in der Variable einsetzen - ist das möglich? Java Basics - Anfänger-Themen 2
N Variable aus anderen Variablen in statischer Klasse berechnen/abspeichern? Java Basics - Anfänger-Themen 4
Y Wie kann ich die Variable in der Try Catch returnen? Java Basics - Anfänger-Themen 3
K Übergabe des Wertes einer Variable aus main() in eine Klassenmethode Java Basics - Anfänger-Themen 8
B Inkrement von Variable Java Basics - Anfänger-Themen 8
V Variablen statische Variable einer Objektvariable zuordnen Java Basics - Anfänger-Themen 3
L Variable von einer Methode zu einer anderen Methode inkl. einer "Zwischenmethode" Java Basics - Anfänger-Themen 1
J JTextField Bezeichnung als Variable Java Basics - Anfänger-Themen 3
N Wie kann ich eine meine Variable Final machen? Java Basics - Anfänger-Themen 1
NeoLexx Variable für Array wird nicht korrekt übergeben Java Basics - Anfänger-Themen 45
M Enum-Variable HashMap zuweisen Java Basics - Anfänger-Themen 5
H Variable um 1 erhört ausgeben Java Basics - Anfänger-Themen 4
V Erste Schritte Eine Array-Variable mit Benutzereingaben befüllen Java Basics - Anfänger-Themen 3
J Fehlermeldung unklar. non-static variable player0 cannot be referenced from a static context Java Basics - Anfänger-Themen 4
P non-static variable cannot be referenced from a static context Java Basics - Anfänger-Themen 6
A Wie zwei zahlen in einer Variable speichern? Java Basics - Anfänger-Themen 7
W Problem mit dem Wert von boolean-Variable Java Basics - Anfänger-Themen 3
M Input/Output JTextField Eingabe in String Variable speichern Java Basics - Anfänger-Themen 15
A Kann man eine Methode als Variable speichern und danach noch verändern? Java Basics - Anfänger-Themen 6
L cannot find symbol variable Kon Java Basics - Anfänger-Themen 8
C Statischer Typ aber Variable nicht statisch? Java Basics - Anfänger-Themen 5
H Variable.methode aufstellen, verstehen Java Basics - Anfänger-Themen 2
R Warnung, wenn eine Variable eingegeben wird Java Basics - Anfänger-Themen 6
S Variable einscannen Java Basics - Anfänger-Themen 30
N Best Practice Rückgabe eines Terminal Befehls in eine Variable speichern Java Basics - Anfänger-Themen 27
M Erste Schritte Mit Variable verschiedene Texte in Textfeld einfügen Java Basics - Anfänger-Themen 27
J Input-Variable nicht sichtbar Java Basics - Anfänger-Themen 2
L Warum ist Variable null? Java Basics - Anfänger-Themen 3
E Variable (Vektor) in andere Methode übergeben Java Basics - Anfänger-Themen 4
A OOP Variable in anderer Klasse durch Methode aufrufen und einer anderen Variable gleichsetzen Java Basics - Anfänger-Themen 2
S Variable Parameter Java Basics - Anfänger-Themen 5
D Datei auslesen & Werte in Variable speichern Java Basics - Anfänger-Themen 12
P if - Statement erkennt variable nicht. Java Basics - Anfänger-Themen 12
J Ungewollte Wertveränderung einer Variable Java Basics - Anfänger-Themen 9
R Variablen Variable an FXML-Controller übergeben Java Basics - Anfänger-Themen 4
J Zugriff auf Variable in anderem Programm Java Basics - Anfänger-Themen 5
R variable istpositiv might not have been initialized Java Basics - Anfänger-Themen 2
A Methodenname aus variable Java Basics - Anfänger-Themen 2
L Variable aus einer Klasse in einer anderen Klasse nutzen Java Basics - Anfänger-Themen 6
P Methode soll Variable einer anderen Klasse ändern. Wie? Java Basics - Anfänger-Themen 1
Hanschyo Variable nicht initialisiert Java Basics - Anfänger-Themen 6
deatzi Variable aus If Abfrage später nutzen Java Basics - Anfänger-Themen 4
L Variable in If-Statement initialisieren Java Basics - Anfänger-Themen 4
C return kann nicht auf variable zugreifen Java Basics - Anfänger-Themen 26
S Wie erstelle ich eine Vorbedingung für eine Variable einer Methode ? Java Basics - Anfänger-Themen 5
S Warum kann ich nicht mehr als eine Variable in einer for Schleife deklarieren ? Java Basics - Anfänger-Themen 1
V Warum speichert meine String-Variable nummerische Werte? Java Basics - Anfänger-Themen 3
J Wert eines Arrays einer Variable zuweisen, sobald der Wert eines anderen Arrays eintritt Java Basics - Anfänger-Themen 2
DaCrazyJavaExpert Compiler-Fehler Variable nicht mit null initialisiert, trotzdem: NullPointerException Java Basics - Anfänger-Themen 28
A Erste Schritte Mein Programm erkennt die variable EinAus.readInt nicht Java Basics - Anfänger-Themen 15
Aprendiendo [JAVA-Syntax] (int... variable) bei einem Konstruktor Java Basics - Anfänger-Themen 8
F Variablen If else: Einer Variable einen Wert hinzufügen oder so? Java Basics - Anfänger-Themen 6
Aprendiendo Interpreter-Fehler "non-static variable this cannot be referenced from a static context" Java Basics - Anfänger-Themen 2
D Aufruf einer statischen Variable Java Basics - Anfänger-Themen 1
F [OOP] Auf eine Variable aus meherer Klassen zugreifen Java Basics - Anfänger-Themen 22
D Einer Variable automatisch Zahlen hinzuaadieren Java Basics - Anfänger-Themen 3
BadBat Klassen instanz als variable + methodenaufruf Java Basics - Anfänger-Themen 4
BadBat Variablen Eine Variable mit 2 Typen Java Basics - Anfänger-Themen 38
S Cannot find symbol (symbol ist eine Variable) Java Basics - Anfänger-Themen 13
K String einlesen und als Variable speichern Java Basics - Anfänger-Themen 8
M Variable noch erstellen oder lieber so? Java Basics - Anfänger-Themen 1
G Variable Objektnamen Java Basics - Anfänger-Themen 43
B Variable in mehreren Klassen nutzen Java Basics - Anfänger-Themen 4
T static String Variable wird nur beim ersten aufruf durch eine Funktion geändert. Java Basics - Anfänger-Themen 16
H Innerhalb einer Methode eine Variable der aufrufenden Methode ändern? Java Basics - Anfänger-Themen 2

Ähnliche Java Themen

Neue Themen


Oben