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

标签 c algorithm binary-search-tree permutation lexicographic

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

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

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/

相关文章:

algorithm - 理解和构建社交网络算法

java - 在骰子值上找到可能的节点

java - 删除二叉搜索树中的节点

algorithm - 红黑树 : Split/Concatenate in log(n) time

c - 读取C上的空间

excel - 我想从周等于当前周的行中搜索/获取五个最小值以及 'Name Headers'

c - 顶点法线的图形问题

c - 二叉搜索树不添加元素

c - TCP 绑定(bind)没有进程绑定(bind)的先验知识

c++ - 我有以字节为单位的串行数据流。读取数据的最简单方法是什么?