使用递归函数(预购)打印二叉搜索树(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 中有很多节点。有人可以建议我其他数据结构/或方法吗?一个建议就足够了,但应该是有效的。