如何在二叉树中搜索并返回节点?
我正在尝试在二叉树中搜索节点,如果它在那里,则返回,否则返回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;
}
}
相关文章