首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >三元搜索树

三元搜索树
EN

Stack Overflow用户
提问于 2011-11-01 19:10:04
回答 2查看 4.4K关注 0票数 5
代码语言:javascript
复制
struct Ternary {

    char current;
    bool wordend;
    Ternary* left;
    Ternary* mid;
    Ternary* right;
    Ternary(char c='@',Ternary* l=NULL, Ternary* m=NULL, Ternary* r=NULL,bool end=false)
    {
        wordend=end;
        current=c;
        left=l;
        mid=m;
        right=r;
    }
};

void add(Ternary* t, string s, int i) {

    if (t == NULL) {
        Ternary* temp = new Ternary(s[i],NULL,NULL,NULL,false);
        t=temp;
    }

    if (s[i] < t->current) {
        add(t->left,s,i);
    }
    else if (s[i] > t->current) {
        add(t->right,s,i);
    }
    else
    {
        if ( i + 1 == s.length()) {
            t->wordend = true;
        }
        else
        {
            add(t->mid,s,i+1);
        }
    }
}

当我使用add()添加单词序列时,字符串被打印到if(t==NULL)片段中,但是树没有形成,即节点没有链接。

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2011-11-01 19:25:13

代码语言:javascript
复制
t=temp;

这一行在add()函数之外不起作用。调用方的指针不会更新。

您可以更改您的函数以返回一个Ternary* (在本例中,在它的末尾返回t ),并将调用地点更改为:

代码语言:javascript
复制
Ternary *tree = 0;
tree = add(tree, "hello", 1);
tree = add(tree, "bye", 1);
...
票数 4
EN

Stack Overflow用户

发布于 2013-01-10 16:41:18

一个小把戏就行了:

替换:

代码语言:javascript
复制
void add(Ternary* t, string s, int i)

通过以下方式:

代码语言:javascript
复制
void add(Ternary*& t, string s, int i)

这比传递,然后像这样读取输出更干净:

代码语言:javascript
复制
tree = add(tree, "bye", 1);

在C++中,利用它们的引用:)在C中,您可以将函数签名更改为:

代码语言:javascript
复制
void add(Ternary** t, string s, int i)

并记住在相关位置更正t

那么,C++显然更干净了:)

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/7965581

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档