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)
段,但树未形成,即节点未链接。 最佳答案
t=temp;
该行在
add()
函数之外无效。调用者的指针未更新。您可以更改函数以返回
Ternary*
(在这种情况下,在其末尾返回t
),并将调用站点更改为:Ternary *tree = 0;
tree = add(tree, "hello", 1);
tree = add(tree, "bye", 1);
...
关于c++ - 三元搜索树,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/7965581/