gpt4 book ai didi

c - 搜索二叉树C,字典顺序,下一个排列,递归

转载 作者:塔克拉玛干 更新时间:2023-11-03 04:42:51 24 4
gpt4 key购买 nike

我有一个家庭作业,完成了大部分,但我卡在了一个点上。我必须搜索二叉树并找到一个关键字,如果关键字没有出现,我必须在树女巫中找到字典顺序的下一个字符串作为前缀我想找到的关键字,直到没有其他字符串满足以前的标准。

下面的代码是在我还没有找到确切的单词时进行搜索。

int successor(TreeNode *v,char* x){

int lenght = strlen(x);
printf("%d\n", lenght);
if (v != NULL) {

if (strncmp(x , v->key, lenght) == 0)
{
// found
printf("%s, %d\n", v->key, v->appears);
}

else if (strncmp(x , v->key, lenght) < 0)
return successor(v->left, x);

else if (strncmp( x , v->key, lenght) > 0)
return successor(v->right, x);

else
printf("Query string not found.\n");
}
}
else return 0; }

例子

如果我有的话:树遍历树

         tree   <---(not root)
traversal trees

如果我搜索:“tr”

我只得到遍历返回。

遍历后我无法向左或向右移动,因为是一片叶子,而且我也找不到显示树和树的方法。

我已经尝试了一些方法,但没有成功,所以现在我要问你,除此之外我什至不知道如何处理字典顺序下一个关键字或我必须用它做什么!

感谢任何帮助! :D

最佳答案

要打印所有包含搜索关键字的单词,您必须遍历树,因为无法提前知道是否有任何后代匹配。

基本方法

要遍历树,您可以使用与此类似的函数:

void
bin_tree_search_inorder(struct TreeNode *t)
{
if (t == NULL)
return;
bin_tree_search_inorder(t->left);
// do check here
bin_tree_search_inorder(t->right);
}

此函数的工作原理是将二叉树尽可能向左遍历,然后从底部开始向右遍历,如此反复。要检查是否包含前缀,您可以使用 strstr 函数:

if (strstr(t->key, key) != 0)
printf("\nMatch: [%s]", t->key);
else
printf("\nDoesn't match: [%s]", t->key);

更好的方法

要限制搜索区域,您可以考虑到只要有机会在树下找到匹配项就应该继续搜索,并且您可以使其更精确:您确切知道何时使用向右、向左或同时向右走。

void
bin_tree_search_inorder(struct t *t, char *key)
{
int res;
if (t == NULL)
return;
if (strstr(t->key, key) != 0)
{
printf("\nMatch: [%s]", t->key);
bin_tree_search_inorder(t->l, key);
bin_tree_search_inorder(t->r, key);
} else {
printf("\nDoesn't match: [%s]", t->key);
if (strlen(t->key) >= strlen(key))
{
res = strcmp(key, t->key);
if (res > 0)
bin_tree_search_inorder(t->l, key);
else
bin_tree_search_inorder(t->r, key);
}
}
}

Working code

用法:

int
main(void)
{
struct t root, l, r, rl, rr, ll, lr;
strcpy(&root.key, "tree");
strcpy(&l.key, "traversal");
strcpy(r.key, "trees");
root.l = &l;
root.r = &r;
l.l = l.r = r.l = r.r = NULL;
strcpy(rl.key, "tre");
strcpy(rr.key, "tx");
r.l = &rl;
r.r = &rr;
rl.l = rl.r = rr.l = rr.r = NULL;
strcpy(ll.key, "ta");
strcpy(lr.key, "travvv");
l.l = &ll;
l.r = &lr;
ll.l = ll.r = lr.l = lr.r = NULL;
bin_tree_search_inorder(&root, "tr");
return 0;
}

输出:

不匹配:[ta]

匹配:[遍历]

匹配:[travvv]

匹配:[树]

匹配:[tre]

匹配:[树]

不匹配:[tx]

关于c - 搜索二叉树C,字典顺序,下一个排列,递归,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34733580/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com