Heim >Java >javaLernprogramm >Ausführliche Erläuterung von Beispielen zum Hinzufügen, Einfügen, Löschen und Erstellen binärer Java-Suchbäume
Der binäre Suchbaum wird auch als binärer Sortierbaum bezeichnet. Er ist entweder ein leerer Baum** oder ein binärer Baum mit den folgenden Eigenschaften:
Wenn sein linker Teilbaum nicht leer ist, dann die Werte aller Knoten im linken Teilbaum sind kleiner als der Wert des Wurzelknotens
Wenn sein rechter Teilbaum nicht leer ist, dann sind die Werte aller Knoten im rechten Teilbaum größer als der Wert des Wurzelknotens
Seine linken und rechten Teilbäume sind jeweils auch der binäre Suchbaum Operation - Einfügen
public Node search(int key) { Node cur = root; while (cur != null) { if(cur.val == key) { return cur; }else if(cur.val < key) { cur = cur.right; }else { cur = cur.left; } } return null; }④Operation-Delete
Der Löschvorgang ist komplizierter, aber sein Prinzip ist relativ einfach zu verstehen
1. cur.left == null
1. cur ist root, dann ist root = cur.right2 , dann ist parent.left = cur.right
3. cur ist nicht root, cur ist parent.right, dann ist parent.right = cur.right
2. right == null
1. cur ist root, dann ist root = cur .left
2. cur ist nicht root, cur ist parent.left, dann ist parent.left = cur.left
3. cur ist parent.right, dann parent.right = cur.left
Second Diese Situation ist die gleiche wie die erste, außer dass hier nicht mehr gezeichnet wird3. richtig != null
Sie müssen zum Löschen die Substitutionsmethode verwenden, d Behandeln Sie das Löschproblem des Knotens
Wenn wir uns in einer Situation befinden, in der weder der linke noch der rechte Teilbaum leer sind, wird das Löschen des Knotens die Struktur des Baums zerstören, daher wird die Sündenbockmethode verwendet, um es zu lösen . Der eigentliche Löschvorgang erfolgt weiterhin in den beiden oben genannten Situationen. Die Eigenschaften des Suchbinärbaums werden hier weiterhin verwendet Die Sucheffizienz stellt die Leistung jeder Operation im binären Suchbaum dar.Wenn für einen binären Suchbaum mit n Knoten die Wahrscheinlichkeit der Suche nach jedem Element gleich ist, ist die durchschnittliche Suchlänge des binären Suchbaums eine Funktion der Tiefe des Knotens im binären Suchbaum, d. h. Je tiefer der Knoten, desto mehr Vergleiche gibt es.
Im optimalen Fall ist der binäre Suchbaum ein vollständiger binärer Baum und seine durchschnittliche Anzahl an Vergleichen beträgt:
Im schlimmsten Fall degeneriert der binäre Suchbaum zu einem einzelnen Zweigbaum und seine durchschnittliche Anzahl an Vergleichen beträgt:public class TextDemo { public static class Node { public int val; public Node left; public Node right; public Node (int val) { this.val = val; } } public Node root; /** * 查找 * @param key */ public Node search(int key) { Node cur = root; while (cur != null) { if(cur.val == key) { return cur; }else if(cur.val < key) { cur = cur.right; }else { cur = cur.left; } } return null; } /** * * @param key * @return */ public boolean insert(int key) { Node node = new Node(key); if(root == null) { root = node; return true; } Node cur = root; Node parent = null; while(cur != null) { if(cur.val == key) { return false; }else if(cur.val < key) { parent = cur; cur = cur.right; }else { parent = cur; cur = cur.left; } } //parent if(parent.val > key) { parent.left = node; }else { parent.right = node; } return true; } public void remove(Node parent,Node cur) { if(cur.left == null) { if(cur == root) { root = cur.right; }else if(cur == parent.left) { parent.left = cur.right; }else { parent.right = cur.right; } }else if(cur.right == null) { if(cur == root) { root = cur.left; }else if(cur == parent.left) { parent.left = cur.left; }else { parent.right = cur.left; } }else { Node targetParent = cur; Node target = cur.right; while (target.left != null) { targetParent = target; target = target.left; } cur.val = target.val; if(target == targetParent.left) { targetParent.left = target.right; }else { targetParent.right = target.right; } } } public void removeKey(int key) { if(root == null) { return; } Node cur = root; Node parent = null; while (cur != null) { if(cur.val == key) { remove(parent,cur); return; }else if(cur.val < key){ parent = cur; cur = cur.right; }else { parent = cur; cur = cur.left; } } } }
Das obige ist der detaillierte Inhalt vonAusführliche Erläuterung von Beispielen zum Hinzufügen, Einfügen, Löschen und Erstellen binärer Java-Suchbäume. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!