【发布时间】:2012-10-07 21:32:10
【问题描述】:
使用递归函数(预购)打印二叉搜索树(BST)时。我需要打印当前节点的所有父节点(路径形式根)。
可以使用辅助数据结构(例如我的代码中的 path),但我不想保留 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 中有很多节点。有人可以建议我其他数据结构/或方法吗?一个建议就足够了,但应该是有效的。
【问题讨论】:
-
据我所知,您需要保留某种结构来跟踪路径,而您的路径数组实际上似乎是最简单的想法。另一种方法是让每个节点都保留一个指向其父节点的指针,但这当然会一直“浪费”这个空间,而不仅仅是在打印时。不过,您可以通过这种方式不分配并使用常量空间进行打印。
-
@YefimDinitz :感谢您的建议 :) ...实际的数据结构(DS)比 BST 复杂得多。我使用术语 BST 来保持问题陈述的简单性,因此我喜欢避免使用父指针……可能任何动态 DS 都会有用,但很难维护:( .
-
我尝试的是传递一个字符串,该字符串包含所有节点,直到路径中的当前节点和要查看的节点。您可以将传递的节点信息连接到字符串,然后打印出节点的数据和新字符串。然后对传递新字符串的孩子执行相同的功能。它运行良好,但可能不是您想要实现它的方式,因为我必须使用字符串流将整数连接到字符串。
标签: c++ c algorithm data-structures advanced-search