如何编写一个函数来检查给定的二叉搜索树是否包含给定的值?

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);
}