再帰関数(事前注文)を使用して二分探索木(BST)を印刷しているとき。現在のノードのすべての親(ルートからのパス)を出力する必要があります。
補助データ構造(たとえば、コード内のパス)を使用できますが、パスを格納するためにnode->pathを保持したくありません。
4 / \ / \ 2 6 / \ / \ 1 3 5 7
事前注文トラバースを使用してノードを行に印刷しているとします。
NODE PATH
4 4
2 4,2
1 4,2,1
3 4,2,3
6 4,6
5 4,6,5
7 4,6,7
私は次のようにしました:うまくいきました!
このコードでは、パスは0(ゼロ)値で終了します。また、BSTにはノード値が0ではありません。
void printpath(int* mypath){
while(*mypath)
printf("%d ", *mypath++);
}
void preorder(struct tree *p, int* path){
int *mypath = calloc(sizeof(path)/sizeof(int) + 1 , sizeof(int*));
int* myp=mypath;
if(p!=NULL){
while( *myp++ = *path++ );
--myp;
*myp=p->data;
*(myp+1)=0;
printf("%d PATH ",p->data);
printpath(mypath);
printf("\n");
preorder(p->left, mypath);
preorder(p->right, mypath);
}
free(mypath);
}
しかし、BSTにはノードがたくさんあるので、パス配列を保持したくありません。誰かが私に他のデータ構造/または方法を提案できますか?提案で十分ですが、効率的である必要があります。