2013-03-15 123 views
0

此函数递归调用自身以搜索Btree,如果找到该值,则返回true;如果未找到,则返回false。如果找不到,我也希望它在最后一次找到“未找到”。它可以正常工作,只是它会自动调用“无法找到”多次(每次它找不到的级别)。B树递归搜索C++

bool lookup(int val, btnode *n) //returns true/false if value is in btree 
{ 

if (n==NULL) return false; //empty tree 

for (int i=0;i< n->count;i++) //check in present node for the val 
    if(n->value[i]==val) 
    { 
     flag = true; 
     return true; 
    } 



//check in child node 

    for(int i =0;i<n->count;i++) //check for child node 
    { if(val < n->value[i]) 
     { cout<<"checking a different node."<<endl; 
      lookup(val,n->child[i]); 
     } 
    } 
    if(val > n->value[(n->count)-1]) 
    { 
     cout<<"searching a right subtree"<<endl; 
     lookup(val, n->child[n->count]); 
    } 
if (flag==false) 
return false; 
else return true; 
} 

bool lookup2(int val, btnode *n) 
{ 
if(lookup(val, n)==false) 
{ 
    cout<<"not found"<<endl; 
    return false; 
} 
else 
{ 
    cout<<"Found it"<<endl; 
    return true; 
    } 
} 
+1

有两个功能。实际打印的一个,以及您现在正在递归执行工作的那个。 – zz3599 2013-03-15 21:12:46

+0

为什么不在调用者那里做这件事,而不是试图在这里使用这种方法呢? – Tawnos 2013-03-15 21:13:26

+0

另外一个'bool contains()'函数几乎没有比'location find()'更有用。 – 2013-03-15 21:18:15

回答

2

您可能想要创建一个调用此查找函数的辅助方法,并进行打印。喜欢的东西:

bool lookup_print(int val, btnode *n) { 
    bool found = lookup(val, n); 
    if (found) { 
     cout << "Found it!" << endl; 
    } else { 
     cout << "Not found..." << endl; 
    } 
    return found; 
} 

此外,您还需要确保,如果他们真的找到一个节点的递归调用正在返回它们的值。所以无论你在哪里,你都会想要类似的东西:

bool found = lookup(val,n->child[i]); 
if (found) { 
    return found; 
} 
+0

我试过这个,不幸的是我得到一个错误的“未找到”,除非值在根节点。即该函数向下遍历到子节点,该节点返回true,但顶层函数将返回false。基本上,如果它返回true我想完成,跳出递归循环,并返回true。否则返回false。 – user1657563 2013-03-15 21:20:31

+0

你在我的答案中使用了第二位代码吗? – Xymostech 2013-03-15 21:25:09

+0

好吧,我采取了你的意见,并添加了一个名为lookup2的辅助功能。我不得不改变的是把一个静态标志,当它被发现时切换为真。 – user1657563 2013-03-15 21:29:53