2-3-4 Baum Problem

Status
Nicht offen für weitere Antworten.

TheDestroyer

Aktives Mitglied
Hallo Leute, hab nen Problem

und zwar soll ich im follgenden Quelltext, den ich soweit fertig habe noch einen Unterlauf einfügen, weiss aber nicht recht wie ich das machen soll. Und zwar soll sich der Baum, nach dem Löschen einzelner Knoten auf der Blattebene neu aufbauen.

Hoffe ihr könnt mir helfen. Vielleicht kann hier jemand, mal die passenden Zeilen mit einsetzten, weiss ja dass das hier sonst nicht üblich ist, aber ihr würdet mir wirklich richtig dolle helfen.

Code:
public class Tree234{

	private class Tree234Node <T extends Comparable<T>>{

		private Comparable[] keys; 
		private Tree234Node[] children;

		private Tree234Node() {
			keys =  new Comparable[2*order];
			children = new Tree234Node[2*order+1];
		}
		// clonen der Knoten und Kinder
		private Tree234Node(Tree234Node copy) {
			keys = copy.keys.clone();
			children = copy.children.clone();
		}
		// bestimmt Position der Knoten
		private void setKeys(Comparable[] k) {
			keys = k;
		}
		// bestimmt Position der Kinder
		private void setChildren(Tree234Node[] c) {
			children = c;
		}
		// Kinder werden auf null gesetzt
		private boolean isLeaf() {
			return (children[0] == null);
		}
		// Vergleich des Knoten mit den mögl. Kindern
		private boolean find(Comparable key) {
			System.out.println(this);
			for (int i = 0; i < children.length; i++) {
				if (i == keys.length || keys[i] == null)
					return children[i].find(key);	// Kind Nachfolger vom Knoten
				int cmp = keys[i].compareTo(key);	// sonst sucht weiter bis Nachfolger gefunden
				if (cmp == 0) return true;
				else if (cmp > 0 && children[i] != null) 
					return children[i].find(key);
				else if (cmp > 0 && isLeaf())		// wenn kein Nachfolger gefunden, wird Knoten neu eingefügt
					return false;
			}
			return false;
		}
		// Löschen eines Schlüssels
		public boolean delete(Comparable newKey,Tree234Node returnNode){
			if (!isLeaf()) {
				for (int i = 0; i < children.length; i++) {
					if (i == keys.length || keys[i] == null){
						newKey = children[i].delete(newKey,returnNode);
						newKey=null;
						break;
					}	
					int cmp = keys[i].compareTo(newKey);
					if (cmp == 0) break;
					else if (cmp > 0) {
						newKey = children[i].delete(newKey,returnNode);
						break;
					}
				}
			}
			/*
			 * wenn das zu löschende Element im Baum vorhanden ist, 
			 * dann ist es in diesem Knoten (new key != null) 
			 */
			if (newKey != null) {
				int i=0;
				while (i < keys.length 
					&& keys[i] != null
					&& keys[i].compareTo(newKey) < 0) 
					i++;
				if (i < keys.length 
					&& keys[i] != null 
					&& keys[i].compareTo(newKey) == 0){ 
					keys[i] = null;//eigentliches löschen
					newKey=null;
					i++;
					/*
					 * nehmen den nächsten Index, der muss, wenn er 
					 * nicht null ist eine Stelle nach links
					 */
					}
				while (i < keys.length) {
					Comparable tmpKey = keys[i];//temporäre speicher variable
					if (tmpKey == null) break;
					Tree234Node tmpNode = children[i];//key und Inhalt muss verschoben werden
							keys[i-1] = tmpKey;//einen nach links
							children[i]= tmpNode;// einen nach links
							i++;//kann ja noch ein Eintrag drinnen sein
				}
			}	
			return false;
			}
			

		
		Comparable insert(Comparable newKey,Tree234Node returnNode) {
			// Einfügeknoten suchen 
			if (!isLeaf()) {
				for (int i = 0; i < children.length; i++) {
					if (i == keys.length || keys[i] == null){
						newKey = children[i].insert(newKey,returnNode);
						break;
					}	
					int cmp = keys[i].compareTo(newKey);
					if (cmp == 0) return null;
					else if (cmp > 0) {
						newKey = children[i].insert(newKey,returnNode);
						break;
					}
				}
			}
			// Einfügeposition in Knoten suchen
			if (newKey != null) {
				int i=0;
				while (i < keys.length 
						&& keys[i] != null
						&& keys[i].compareTo(newKey) < 0) 
					i++;
				if (i < keys.length 
						&& keys[i] != null 
						&& keys[i].compareTo(newKey) == 0) 
					return null;
				Comparable tmpKey = null;
				Tree234Node tmpNode = null;
				Tree234Node newNode = new Tree234Node(returnNode);
				
				
				// Einfügen und Nachfolger weiterrücken
				while (i < keys.length) {
					tmpKey = keys[i];
					tmpNode = children[i+1];
					keys[i] = newKey;
					children[i+1] = (newNode == null || isLeaf()) ?
						null :
						newNode;
					newKey = tmpKey;
					newNode = tmpNode;
					i++;
				}
				// Überlaufbehandlung
				if (newKey != null) {
					
					/*
					 * neuen Knoten erzeugen, Schluessel kopieren 
					 * und aus altem Knoten loeschen
					 */ 
									 
					tmpNode = new Tree234Node();
					for (i = 0; i < order-1; i++) {
						tmpNode.keys[i] = keys[order+i+1];
						tmpNode.children[i] = children[order+i+1];
						keys[order+i+1] = null;
						children[order+i+1] = null;
					}
					tmpNode.children[order-1] = children[2*order]; // Ordnung des Baums bestimmt
					children[2*order] = null; 
					tmpNode.keys[order-1] = newKey;
					tmpNode.children[order] = (newNode == null || isLeaf()) ?
						null :
						newNode;
					
					// mittlerer Schluessel als Rueckgabewert
					newKey = keys[order];
					keys[order] = null;
					children[order+1] = null;
					
					// Werte des Rueckgabeknoten setzen
					returnNode.setKeys(tmpNode.keys.clone());
					returnNode.setChildren(tmpNode.children.clone());
				}
			}
			return newKey;
		}
		// toString Methode eingesetzt
		public String toString() {
			String res = "[";
			for (int i = 0; i < keys.length; i++) 
				res = res + " " + keys[i] + " ";
			res += "]";
			return res;
		}
		// Niveau des Knotens wird bestimmt
		private String toString(int level) {
			String res = "";
			int i = 0;
			for (i = 0; i < level; i++) res += " ";
			res = res + this + "\n";
			for (i = 0; i < children.length; i ++)
				if (children[i] != null)
					res += children[i].toString(level+1);
			return res;

		}
	}
	
	int order;
	Tree234Node root = null;
	// Methoden für den Baum
	public Tree234(int o) {
		order = o;
		root = new Tree234Node();
	}
	// Vergleich 
	public boolean find(Comparable key) {
		return root.find(key);
	}
	// Einfügen neuer Schlüssel
	public void insert(Comparable newKey) {
		Tree234Node returnNode = new Tree234Node();
		Comparable newRootKey = root.insert(newKey, returnNode);
		if (newRootKey != null) {
			Tree234Node newRoot = new Tree234Node();
			newRoot.keys[0] = newRootKey;
			newRoot.children[0] = root;
			newRoot.children[1] = returnNode;
			root = newRoot;
		}
	}
	// Methode um Schlüssel zu löschen
	public boolean delete(Comparable loeschen){
		Tree234Node returnNode = new Tree234Node();
		Comparable newRootKey = root.delete(loeschen, returnNode);
		if (newRootKey != null) {
			Tree234Node newRoot = new Tree234Node();
			newRoot.keys[0] = newRootKey;
			newRoot.children[0] = root;
			newRoot.children[1] = returnNode;
			root = newRoot;
		}
		return false;
		
	}
	
	public String toString() {
		String res = "Tree234:\n------\n";
		return (res + root.toString(0));
	}

	// Ausgabe des Baumes
	public static void main(String[] args) {
		Tree234 tree234 = new Tree234(2);
		Integer[] inserts = {7, 19, 23, 4, 12, 17, 8, 11, 2, 9, 13};
		for (Integer i : inserts) {
			System.out.println("\nInsert: " + i);
			tree234.insert(i);
			System.out.println(tree234);
		}
		
		tree234.delete(23);
		System.out.println(tree234+"test");
	}
}
 

Leroy42

Top Contributor
Abgesehen davon, daß hier wohl kaum jemand auf Anhieb
weiß was ein 2-3-4-Baum ist, bzw. auf welche von mehreren
ähnlichen Definitionen du dich beziehst(beziehen sollst),
hat wohl kaum jemand Lust, sich einen Baum-Restrukturierungsalgorithmus
aus den Fingern zu saugen und in ein bestehendes, 250 Zeilen starkes,
Programm einzufügen :?

Ich schätze mal, daß du weitaus mehr Informationen hast,
die notwendigen Änderungen zumindest schon mal zu versuchen.

Wenn du dabei konkrete Schwierigkeiten hast, wird dir hier sicher
gerne weitergeholfen werden.

Aber so, ... :roll:
 

Redfrettchen

Bekanntes Mitglied
Ein 2-3-4-Baum ist laut Wikipedia ein B-Baum zweiter Ordnung (man muss ja auch für jeden *** einen eigenen Namen finden ~~).

Jo, aber durch den komischen Code jetzt durchwursteln und auch noch was komplexes dazu schreiben, dazu hab ich persönlich keine Lust.
 
Status
Nicht offen für weitere Antworten.
Ähnliche Java Themen
  Titel Forum Antworten Datum
S Problem mit Baum AWT, Swing, JavaFX & SWT 4
R JavaFX Baum mit JFXTreeTable AWT, Swing, JavaFX & SWT 0
D SWT TreeViewer: Daten aus Model gelöscht... trotzdem noch im Baum AWT, Swing, JavaFX & SWT 4
H 2D-Grafik Bibliothek um Graph\Baum zu erstellen AWT, Swing, JavaFX & SWT 2
2 Einfacher Baum visualisieren. AWT, Swing, JavaFX & SWT 11
U Baum/Tree nach Benutzer anzeigen AWT, Swing, JavaFX & SWT 3
A Gemeinsames Model für Baum- und Graphdarstellung-wie gehts? AWT, Swing, JavaFX & SWT 9
G Problem mit der Anzeige von jLabel. Unlesbar wenn der Text geändert wird. AWT, Swing, JavaFX & SWT 28
H 2D-Grafik Problem mit Paint AWT, Swing, JavaFX & SWT 1
S Layout - Problem AWT, Swing, JavaFX & SWT 1
Tassos JavaFX/Problem mit der Maussteuerung in Stackpane AWT, Swing, JavaFX & SWT 7
sserio Java Fx - Problem AWT, Swing, JavaFX & SWT 3
A Problem Spiel auf Panel der GUI zu bringen AWT, Swing, JavaFX & SWT 1
A JavaFX Controller Problem AWT, Swing, JavaFX & SWT 1
TheWhiteShadow JavaFX ListView Problem beim Entfernen von Elementen AWT, Swing, JavaFX & SWT 1
E LayoutManager Welcher Layout-Mix löst mein Problem? AWT, Swing, JavaFX & SWT 3
Umb3rus JavaFX Problem mit PropertyValueFactory: can not read from unreadable property AWT, Swing, JavaFX & SWT 1
T Problem mit paintComponent() AWT, Swing, JavaFX & SWT 17
AmsananKING Java Menü-Problem AWT, Swing, JavaFX & SWT 1
K JavaFX Resizing-Problem beim BorderLayout (Center Component) beim Arbeiten mit mehreren FXMLs AWT, Swing, JavaFX & SWT 2
G Instance OF Problem AWT, Swing, JavaFX & SWT 9
FrittenFritze Ein Problem mit der CSSBox, die Größe wird nicht angepasst AWT, Swing, JavaFX & SWT 5
M Problem mit dem Anzeigen von Frames im Vordergrund AWT, Swing, JavaFX & SWT 5
Badebay Problem mit JButton AWT, Swing, JavaFX & SWT 2
newJavaGeek Grid-Layout problem AWT, Swing, JavaFX & SWT 7
J JavaFX Löschen im Tabelview macht Problem AWT, Swing, JavaFX & SWT 15
JavaTalksToMe JavaFx ExekutorService Problem AWT, Swing, JavaFX & SWT 2
Zrebna Problem bei Eventhandling (Value soll nach jedem erneutem Klick gelöscht werden) AWT, Swing, JavaFX & SWT 4
B Problem mit JavaFX AWT, Swing, JavaFX & SWT 5
J css Problem AWT, Swing, JavaFX & SWT 5
B JavaFX habe mein Problem fett markiert AWT, Swing, JavaFX & SWT 2
A Swing Filter-Problem AWT, Swing, JavaFX & SWT 1
temi JavaFX Problem mit IntelliJ und JavaFx 11 unter XUbuntu AWT, Swing, JavaFX & SWT 3
L Java FX Problem mit Ubuntu 18 und JavaFx AWT, Swing, JavaFX & SWT 27
H JTable TableCellEditor-Problem AWT, Swing, JavaFX & SWT 0
kodela Swing Problem mit Warten-Dialog AWT, Swing, JavaFX & SWT 16
B JavaFx Scene Builder Problem AWT, Swing, JavaFX & SWT 2
B [Problem] Java öffnet Word-Datein nicht AWT, Swing, JavaFX & SWT 14
T DataBinding Problem AWT, Swing, JavaFX & SWT 5
Blender3D Problem mit € Symbol Font Gotham Windows 10 Swing AWT, Swing, JavaFX & SWT 11
T Problem mit JTable Sortierung AWT, Swing, JavaFX & SWT 2
J Problem mit Platfrom run later AWT, Swing, JavaFX & SWT 15
J Problem mit Platfrom run later AWT, Swing, JavaFX & SWT 0
D Swing SwingUtils / Thread Problem AWT, Swing, JavaFX & SWT 3
L JavaFX Problem beim Aufrufen einer Methode AWT, Swing, JavaFX & SWT 5
T Swing Problem mit Datum und FormattedTextField AWT, Swing, JavaFX & SWT 2
S AWT Java print dialog Problem AWT, Swing, JavaFX & SWT 0
olfibits JavaFX Problem mit HTMLEditor AWT, Swing, JavaFX & SWT 0
W SWT hover-background-problem with first column in TreeViewer AWT, Swing, JavaFX & SWT 0
M Problem mit Add JScrollPane AWT, Swing, JavaFX & SWT 25
Mario1409 Swing JTextArea scroll Problem AWT, Swing, JavaFX & SWT 0
N Swing Problem mit loop AWT, Swing, JavaFX & SWT 2
S Swing Problem mit Button und ActionListener AWT, Swing, JavaFX & SWT 5
S Swing & Clean und build Problem AWT, Swing, JavaFX & SWT 12
S JLabel setText() Problem AWT, Swing, JavaFX & SWT 6
I 2D-Grafik Problem beim Ändern der Farbe eine 2d Objekts AWT, Swing, JavaFX & SWT 3
G Swing Splitpane Problem AWT, Swing, JavaFX & SWT 1
F Problem mit der FXML Rectangle Shape AWT, Swing, JavaFX & SWT 2
N JavaFX Stranges Problem mit der Autoscroll-Eigenschaft von Textareas AWT, Swing, JavaFX & SWT 0
E Java FX FXML Problem mit html Scriptausführung AWT, Swing, JavaFX & SWT 2
J JavaFX Intersect Problem mit Shapes AWT, Swing, JavaFX & SWT 10
R JavaFX MediaPlayer AVI-Problem AWT, Swing, JavaFX & SWT 1
M Swing Problem mit ListCellRenderer AWT, Swing, JavaFX & SWT 7
D Problem mit JTable AWT, Swing, JavaFX & SWT 1
F GUI Auflösung ändern - Koordianten und Proportions Problem AWT, Swing, JavaFX & SWT 21
J Problem mit Button darstellung AWT, Swing, JavaFX & SWT 23
M Problem mit Layoutmanagern... Hilfe wäre sehr nett. AWT, Swing, JavaFX & SWT 2
S 2D-Grafik Problem mit Variablen AWT, Swing, JavaFX & SWT 4
7 JavaFX Problem beim Zeichnen eines Dreiecks in einem GUI AWT, Swing, JavaFX & SWT 6
M Swing AttributiveCellTableModel addRow() Problem AWT, Swing, JavaFX & SWT 1
J Swing Problem mit Graphics Methode AWT, Swing, JavaFX & SWT 4
N JavaFX Problem mit table multiple selection AWT, Swing, JavaFX & SWT 5
K CheckBox Problem AWT, Swing, JavaFX & SWT 5
Grevak DisplayMode Problem seit Windows 10 AWT, Swing, JavaFX & SWT 2
S Swing Eigene JComboBox Problem! AWT, Swing, JavaFX & SWT 1
B Swing Problem mit Bildpfad AWT, Swing, JavaFX & SWT 4
N Swing Problem beim Scrollen mit JScrollPane AWT, Swing, JavaFX & SWT 6
V Graphics g - drawOval problem mit background AWT, Swing, JavaFX & SWT 1
C AWT Problem mit Protokol Fenster AWT, Swing, JavaFX & SWT 0
M Swing pack() Problem mit Taskleiste AWT, Swing, JavaFX & SWT 4
N Swing Choice- Problem! AWT, Swing, JavaFX & SWT 8
Q "AWT-EventQueue-0" Exception Problem AWT, Swing, JavaFX & SWT 4
D jButton Problem, ein Rieser Button bedeckt das ganze frame AWT, Swing, JavaFX & SWT 1
A Problem: repaint() - Schleife AWT, Swing, JavaFX & SWT 3
J Anfänger GUI Problem bei der Ausführung eines sehr einfachen Programms AWT, Swing, JavaFX & SWT 2
P AWT Problem mit Platzierung (GridBagLayout) AWT, Swing, JavaFX & SWT 2
N Swing JTree Problem beim erstellen der Knoten AWT, Swing, JavaFX & SWT 0
N Swing CardLayout: Problem beim Wechsel zwischen den JPanels AWT, Swing, JavaFX & SWT 3
A Mini-Menu-Schriften. Ein Problem bei hohen DPI Zahlen AWT, Swing, JavaFX & SWT 2
Z Canvas in Frame einfügen. Problem mit 4-Gewinnt AWT, Swing, JavaFX & SWT 1
C Thread-/ Simulations- Problem AWT, Swing, JavaFX & SWT 18
G Swing Setvisible problem AWT, Swing, JavaFX & SWT 1
J JTabbedPane: close Button Problem AWT, Swing, JavaFX & SWT 2
Tom299 JavaFX -> fxmlLoader -> getResourceAsStream Problem AWT, Swing, JavaFX & SWT 1
T Problem: ComboBox und addItem AWT, Swing, JavaFX & SWT 5
M JTextArea wird nicht aktualisiert (ActionListener-Problem) AWT, Swing, JavaFX & SWT 1
T LayoutManager LookAndFeel-Problem AWT, Swing, JavaFX & SWT 4
F Problem mit Implementierung von Kollisionsabfrage AWT, Swing, JavaFX & SWT 5
vodkaz (javafx) Image Problem AWT, Swing, JavaFX & SWT 2
T Problem beim Zeichnen von Rechteck AWT, Swing, JavaFX & SWT 3

Ähnliche Java Themen

Neue Themen


Oben