Top Menu

Jump to content
Home
    • Projects
    • Work packages
    • News
    • Getting started
    • Introduction video
      Welcome to OpenProject
      Get a quick overview of project management and team collaboration with OpenProject. You can restart this video from the help menu.

    • Help and support
    • Upgrade to Enterprise edition
    • User guides
    • Videos
    • Shortcuts
    • Community forum
    • Professional support

    • Additional resources
    • Data privacy and security policy
    • Digital accessibility (DE)
    • OpenProject website
    • Security alerts / Newsletter
    • OpenProject blog
    • Release notes
    • Report a bug
    • Development roadmap
    • Add and edit translations
    • API documentation
  • Sign in
      Create a new account
      Forgot your password?

Side Menu

  • Overview
  • News
  • Forums
  • Wiki
    • Table of contents
      • Expanded. Click to collapseCollapsed. Click to showWiki
        • Expanded. Click to collapseCollapsed. Click to showBeispielprojekte
          • Hierarchy leafFlappy Box2D
          • Hierarchy leafFlappy Improved
          • Hierarchy leafHighscore Hibernate
          • Hierarchy leafHighscore Webservice + Anbindung mit Retrofit
        • Expanded. Click to collapseCollapsed. Click to showEntwicklung mit Java
          • Hierarchy leaf001) Grundlagen - Entwicklungsumgebung
          • Hierarchy leaf002) Erstes Programm
          • Hierarchy leaf003) Variablen und Datentypen
          • Expanded. Click to collapseCollapsed. Click to show004) Schleifen
            • Hierarchy leaf1) for - Zählschleife
            • Hierarchy leaf2) while
            • Hierarchy leaf3) do while
            • Hierarchy leaf4) for each
          • Hierarchy leaf005) Arrays
          • Hierarchy leaf006) Methoden
          • Expanded. Click to collapseCollapsed. Click to show007) Objektorientierte Programmierung
            • Hierarchy leaf001) Klasse
            • Hierarchy leaf002) Vererbung und Darstellung von Klassen in UML
            • Hierarchy leaf003) Abstrakte Klasse
            • Hierarchy leaf004) Design patterns
          • Expanded. Click to collapseCollapsed. Click to show008) Webservices
            • Hierarchy leaf01) REST - Representational State Transfer
            • Hierarchy leaf02) Minimaler Webservice
            • Hierarchy leaf03) Joke Webservice
            • Hierarchy leaf04) Highscore Service
        • Expanded. Click to collapseCollapsed. Click to showMatura - Vorbereitung
          • Hierarchy leaf01) Projektmanagement
          • Hierarchy leaf02) Objektorientierte Programmierung
          • Hierarchy leaf03) Modellierung und UML
          • Expanded. Click to collapseCollapsed. Click to show04) Design Patterns
            • Hierarchy leaf00) Generelle Konzepte
            • Hierarchy leafFactory(-Method) Pattern
            • Hierarchy leafObserver Pattern
            • Hierarchy leafSingleton Pattern
            • Hierarchy leafStrategy Pattern
          • Hierarchy leaf05) Algorithmen und Datenstrukturen
          • Hierarchy leaf06) Webtechnologien
          • Hierarchy leaf07) Webservices
          • Hierarchy leaf08) Softwarequalitätsmanagement
          • Hierarchy leaf09) Softwareentwicklungsmodelle
        • Expanded. Click to collapseCollapsed. Click to showProjekt Rahmenbedingungen
          • Expanded. Click to collapseCollapsed. Click to showRetrospektive
            • Hierarchy leafRetro - [Name Schüler_in]
        • Hierarchy leafReact Native
        • Expanded. Click to collapseCollapsed. Click to showÜbungen
          • Hierarchy leaf1) Basic
          • Expanded. Click to collapseCollapsed. Click to show2) Basic
            • Hierarchy leaf001) Methode ohne Rückabewert mit Parametern
            • Hierarchy leaf002) Methode mit Parametern und Rückgabewert
            • Hierarchy leaf003) Text umdrehen
            • Hierarchy leaf004) Text umdrehen 2
            • Hierarchy leaf005) Kommandozeile
            • Hierarchy leaf006) Kommandozeile 2
            • Hierarchy leaf007) Vererbung - Geometry
            • Hierarchy leaf008) File from String
            • Hierarchy leaf009) Rekursion - Summe
            • Hierarchy leaf010) Rekursion - File
          • Expanded. Click to collapseCollapsed. Click to showDatenstrukturen
            • Hierarchy leaf011) Binärbaum
            • Hierarchy leaf012) Binärbaum - Generics
            • Hierarchy leaf013) AVL - Tree
            • Hierarchy leaf014) Linked List - Einfach verkettete Liste
            • Hierarchy leaf015) Graph
            • Hierarchy leaf016) Dijkstras shortest path first
          • Expanded. Click to collapseCollapsed. Click to showJava - Kara
            • Hierarchy leafKara lernt schreiben
You are here:
  • Wiki
  • Übungen
  • Datenstrukturen
  • 011) Binärbaum

Content

011) Binärbaum

  • More
    • Print
    • Table of contents

Binary Search Tree

  • Ein Baum ist eine Datenstruktur welche eine Wurzel und beliebig viele Blätter hat, wobei man sich den Baum um 180° gedreht vorstellen muss (siehe Grafik unten, 8 ist die Wurzel, alle anderen Elemente sind die Blätter)
  • Beim Einfügen eines Wertes verhält sich ein binärer Suchbaum folgendermaßen:
    1. Der übergebene Wert wird in eine Node (Knoten verpackt)
    2. Ist der Baum leer, so wird der aktuelle Knoten zur Wurzel
    3. Ist der Baum nicht leer so wird geprüft ob der Wert des aktuellen Knotens < oder >= der Wurzel ist
      • < (Kleiner)
        • Der linke Platzhalter der Wurzel ist leer -> Aktueller Knoten wird in den linken Platzhalter gesetzt
        • Der linke Platzhalter der Wurzel ist nicht leer -> Zurück zu 3), jedoch wird nicht mehr mit der Wurzel geprüft sondern mit dem linken Platzhalter
      • >= (Größer gleich)
        • Der rechte Platzhalter der Wurzel ist leer -> Aktueller Knoten wird in den linken Platzhalter gesetzt
        • Der rechte Platzhalter der Wurzel ist nicht leer -> Zurück zu 3), jedoch wird nicht mehr mit der Wurzel geprüft sondern mit dem rechten Platzhalter
      • Dies erfordert einen rekursiven Aufruf, das heißt, die Methode ruft sich selbst auf
  • Der binäre Suchbaum soll fürs erste einfach nur mit Ganzzahlen (int)  funktionieren.
  • Erstelle die Datenstruktur für einen Binären Suchbaum in der Klasse BinarySearchTree.
    • Erstelle folgende Methoden
      • public void addValue(int value) { ... }
      • public void traverseInOrder() { ... }
        • Diese Methode soll den Baum in In-Order durchlaufen und die Werte der Elemente ausgeben
      • public List<Integer> getElementsInOrder() { ... }
        • Soll die Liste der Elemente In-Order zurückgeben
  • Erstelle die Klasse Node für die Blätter des Baums
    • Eine Node enthält einen Wert
    • Platzhalter für die Node auf der linken Seite
    • Platzhalter für die Node auf der rechten Seite
  • Teste deine BinarySearchTree Klasse ausgiebig mit Unit tests
  • Kannst du deine Datenstruktur verwenden um eine Liste zu sortieren?

Loading...