この関数は、自身を再帰的に呼び出して Btree を検索し、値が見つかった場合は true を返し、見つからなかった場合は false を返します。また、見つからない場合は最後に「見つかりません」と1回カウントしたいです。それ自体を呼び出すため、「見つかりません」と何度も(「見つからない」というレベルに下がるたびに)表示されることを除いて、正常に動作します。
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;
}
}