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);
}
}
}
Khi tôi thêm chuỗi các từ sử dụng add()
chuỗi đang nhận được in bên trong if(t==NULL)
phân khúc nhưng cây không bị hạch tức là hình thành không nhận được liên kết.ternary Search Tree
hoặc kê khai lập luận như add (ternary ** t, chuỗi s, int i) và sau đó làm * t = tạm –
Thay vì sử dụng tạm thời, tôi cũng đã cố gắng như sau tuyên bố t = new Ternary (s [i]); Và nếu tôi sử dụng cây = ... thì im mất nút gốc của cây của cây – CoderXX
@Pratik: không thay đổi bất kỳ thứ gì trong mã của bạn ngoại trừ việc đặt 'return t;' ở cuối 'add()' và sử dụng 'add như tôi đã chỉ ra, bạn sẽ không mất bất cứ thứ gì. – Mat