Merge pull request #3314 from eugenp/pivovarit-patch-3
Update BinaryTree.java
This commit is contained in:
commit
5374dbb96c
|
@ -21,9 +21,6 @@ public class BinaryTree {
|
||||||
current.left = addRecursive(current.left, value);
|
current.left = addRecursive(current.left, value);
|
||||||
} else if (value > current.value) {
|
} else if (value > current.value) {
|
||||||
current.right = addRecursive(current.right, value);
|
current.right = addRecursive(current.right, value);
|
||||||
} else {
|
|
||||||
// value already exists
|
|
||||||
return current;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return current;
|
return current;
|
||||||
|
@ -38,11 +35,7 @@ public class BinaryTree {
|
||||||
}
|
}
|
||||||
|
|
||||||
private int getSizeRecursive(Node current) {
|
private int getSizeRecursive(Node current) {
|
||||||
if (current == null) {
|
return current == null ? 0 : getSizeRecursive(current.left) + 1 + getSizeRecursive(current.right);
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
return getSizeRecursive(current.left) + 1 + getSizeRecursive(current.right);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public boolean containsNode(int value) {
|
public boolean containsNode(int value) {
|
||||||
|
@ -50,17 +43,17 @@ public class BinaryTree {
|
||||||
}
|
}
|
||||||
|
|
||||||
private boolean containsNodeRecursive(Node current, int value) {
|
private boolean containsNodeRecursive(Node current, int value) {
|
||||||
|
|
||||||
if (current == null) {
|
if (current == null) {
|
||||||
return false;
|
return false;
|
||||||
} else if (value == current.value) {
|
|
||||||
return true;
|
|
||||||
} else if (value < current.value) {
|
|
||||||
return containsNodeRecursive(current.left, value);
|
|
||||||
} else {
|
|
||||||
return containsNodeRecursive(current.right, value);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (value == current.value) {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
return value < current.value
|
||||||
|
? containsNodeRecursive(current.left, value)
|
||||||
|
: containsNodeRecursive(current.right, value);
|
||||||
}
|
}
|
||||||
|
|
||||||
public void delete(int value) {
|
public void delete(int value) {
|
||||||
|
@ -92,23 +85,18 @@ public class BinaryTree {
|
||||||
current.value = smallestValue;
|
current.value = smallestValue;
|
||||||
current.right = deleteRecursive(current.right, smallestValue);
|
current.right = deleteRecursive(current.right, smallestValue);
|
||||||
return current;
|
return current;
|
||||||
|
}
|
||||||
} else if (value < current.value) {
|
if (value < current.value) {
|
||||||
current.left = deleteRecursive(current.left, value);
|
current.left = deleteRecursive(current.left, value);
|
||||||
return current;
|
return current;
|
||||||
} else {
|
}
|
||||||
|
|
||||||
current.right = deleteRecursive(current.right, value);
|
current.right = deleteRecursive(current.right, value);
|
||||||
return current;
|
return current;
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
private int findSmallestValue(Node root) {
|
private int findSmallestValue(Node root) {
|
||||||
|
return root.left == null ? root.value : findSmallestValue(root.left);
|
||||||
if (root.left == null) {
|
|
||||||
return root.value;
|
|
||||||
}
|
|
||||||
|
|
||||||
return findSmallestValue(root.left);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public void traverseInOrder(Node node) {
|
public void traverseInOrder(Node node) {
|
||||||
|
|
Loading…
Reference in New Issue