java - 如何在二叉树中搜索一个节点并返回它?

标签 java binary-tree treenode

我正在尝试在二叉树中搜索一个节点,如果存在则返回,否则返回 null。顺便说一句,节点类有一个方法 name() 返回一个带有它的名字的字符串......我到目前为止是:

private Node search(String name, Node node){

     if(node != null){
         if(node.name().equals(name)){
            return node;
         }

      else{
         search(name, node.left);
         search(name, node.right);
      }
    }
    return null;
}

这是正确的吗??

最佳答案

如果结果不为空,您需要确保对搜索的递归调用返回。

像这样的东西应该有用...

private Node search(String name, Node node){
    if(node != null){
        if(node.name().equals(name)){
           return node;
        } else {
            Node foundNode = search(name, node.left);
            if(foundNode == null) {
                foundNode = search(name, node.right);
            }
            return foundNode;
         }
    } else {
        return null;
    }
}

关于java - 如何在二叉树中搜索一个节点并返回它?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/5938486/

相关文章:

java - HTTP 代理 Servlet 错误

java - 层序树遍历

data-structures - 每个节点存储多个值的树

extjs - Sencha 架构师 : Build a tree

c - 二叉树提取代码

C:如何在函数中返回tree_node?

java - 如何使用java处理大量字符串?

java - Android 数组列表添加值后返回 Null

java - 无法将值 ajax 传递给 servlet

java - 打印两个节点之间的路径路由