此函数递归调用自身以搜索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;
}
}
有两个功能。实际打印的一个,以及您现在正在递归执行工作的那个。 – zz3599 2013-03-15 21:12:46
为什么不在调用者那里做这件事,而不是试图在这里使用这种方法呢? – Tawnos 2013-03-15 21:13:26
另外一个'bool contains()'函数几乎没有比'location find()'更有用。 – 2013-03-15 21:18:15