如何编写一个函数来检查给定的二叉搜索树是否包含给定的值?
How to write a function that checks if a given binary search tree contains a given value?
例如,对于以下树:
n1(值:1,左:空,右:空)
n2(值:2,左:n1,右:n3)
n3(值:3,左:空,右:空)
调用 contains(n2, 3) 应该 return 为真,因为根在 n2 的树包含数字 3。
我是编程新手,正在尝试解决理解编程概念的挑战。这不是作业题。
我写了下面的代码,但它总是 return 错误。
class Node {
public int value;
public Node left, right;
public Node(int value, Node left, Node right) {
this.value = value;
this.left = left;
this.right = right;
}
}
public class BinaryTree {
public static boolean contains(Node root, int value){
if(root == null) return false;
else
return
contains(root.left, value) ||
contains(root.right, value);
}
public static void main(String[] args) {
Node n1 = new Node(1, null, null);
Node n3 = new Node(3, null, null);
Node n2 = new Node(2, n1, n3);
System.out.println(contains(n2,3));
}
}
您没有检查节点上的值是否与您搜索的值相对应。所以你基本上总是 return false 因为在某一时刻 root 将等于 null。为避免这种情况,您需要一个 else if 子句,您可以在其中检查节点的值和搜索到的值,如果这两者相等,则 return 为真。
public static boolean contains(Node root, int value){
if(root == null) return false;
else if (root.value==value) return true;
else
return
contains(root.left, value) ||contains(root.right, value);
}
例如,对于以下树:
n1(值:1,左:空,右:空) n2(值:2,左:n1,右:n3) n3(值:3,左:空,右:空) 调用 contains(n2, 3) 应该 return 为真,因为根在 n2 的树包含数字 3。
我是编程新手,正在尝试解决理解编程概念的挑战。这不是作业题。
我写了下面的代码,但它总是 return 错误。
class Node {
public int value;
public Node left, right;
public Node(int value, Node left, Node right) {
this.value = value;
this.left = left;
this.right = right;
}
}
public class BinaryTree {
public static boolean contains(Node root, int value){
if(root == null) return false;
else
return
contains(root.left, value) ||
contains(root.right, value);
}
public static void main(String[] args) {
Node n1 = new Node(1, null, null);
Node n3 = new Node(3, null, null);
Node n2 = new Node(2, n1, n3);
System.out.println(contains(n2,3));
}
}
您没有检查节点上的值是否与您搜索的值相对应。所以你基本上总是 return false 因为在某一时刻 root 将等于 null。为避免这种情况,您需要一个 else if 子句,您可以在其中检查节点的值和搜索到的值,如果这两者相等,则 return 为真。
public static boolean contains(Node root, int value){
if(root == null) return false;
else if (root.value==value) return true;
else
return
contains(root.left, value) ||contains(root.right, value);
}