首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >线程二叉树的优点

线程二叉树的优点
EN

Stack Overflow用户
提问于 2014-10-08 16:39:17
回答 1查看 203关注 0票数 1

在线程二叉树的文档中,我读到

二叉树遍历的递归和非递归过程都需要将指向所有空闲节点的指针暂时保存在堆栈中。这可以通过使用线程二叉树来避免。

我的问题是

1-在普通二叉树中指针是如何和何时保存在堆栈中的?

2-如何在线程二叉树中的堆栈中不添加指针?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2014-10-08 17:17:39

( 1)他们在谈论走路。您可以使用recusrive算法(它使用CPU堆栈来为您跟踪),也可以使用迭代方法,保持数据结构堆栈,并管理您自己需要访问的节点。后者可能执行得更好,因为您消除了函数调用的开销,但在概念上往往更难理解。

2)线程树保存如何在树本身中遍历树的信息(而不是必须回溯它们指向树中的下一个位置的空指针),这允许您“以一条直线”遍历树,因此不需要堆栈。

wiki页面在展示这一点方面做得很好。

-A

票数 3
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/26262011

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档