1

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

下面的代码用于在我没有找到确切的单词后进行搜索。

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 traversal trees

         tree   <---(not root)
traversal    trees

如果我搜索:“tr”

我只得到遍历。

遍历原因是一片叶子后,我不能向左或向右走,而且我也找不到出现树和树的方法。

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

任何帮助表示赞赏!:D

4

1 回答 1

2

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

基本方法

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

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);
        }
    }
} 

工作代码

用法:

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]

匹配:[树]

比赛:[三]

匹配:[树]

不匹配:[tx]

于 2016-01-12T01:12:39.827 回答