搜索
编程论坛
→
开发语言
→
『 C语言论坛 』
→ 计算树的高度
标题:
计算树的高度
只看楼主
renkejun1942
来 自:不是这样
等 级:
贵宾
威 望:
33
帖 子:1645
专家分:5297
注 册:2016-12-1
结帖率:
95.65%
楼主
已结贴
√
问题点数:20 回复次数:5
计算树的高度
计算树的高度的迭代版本有点麻烦啊。
我想到的思路,先寻找叶节点,然后从根往叶节点走,每循环一次计数器加1,比较计数器的值,最大值即为树的高度。
但是这样做,会好慢,特别是叶节点非常多的时候。
[此贴子已经被作者于2017-5-13 23:09编辑过]
搜索更多相关主题的帖子:
计数器
最大值
2017-05-13 23:00
yangfrancis
等 级:
贵宾
威 望:
141
帖 子:1510
专家分:7661
注 册:2014-5-19
第
2
楼
得分:10
说来迭代应该比递归快啊。就一个变量记录当前深度,每深入一层递增一,回溯一次减少一,深度大于max的时候替换max, 这个计算量无非就是前中后序遍历,感觉应该不会花太多时间吧。当然如果你叶节点比一般二叉树多得多就没法了
2017-05-13 23:18
renkejun1942
来 自:不是这样
等 级:
贵宾
威 望:
33
帖 子:1645
专家分:5297
注 册:2016-12-1
第
3
楼
得分:0
回复 2楼 yangfrancis
用我现在的思路,先寻找叶节点,然后再从根往叶节点走,这样会产生一个嵌套循环。
for( 叶节点数组不为空 )
for(TP不为空)
if(......)
Tp = Tp->Left;
if(........)
TP = TP->Right;
[此贴子已经被作者于2017-5-13 23:25编辑过]
09:30 05/21 种下琵琶种子,能种活么?等待中……
21:50 05/27 没有发芽。
20:51 05/28 没有发芽。
23:03 05/29 没有发芽。
23:30 06/09 我有预感,要发芽了。
2017-05-13 23:22
九转星河
来 自:长长久久
等 级:
贵宾
威 望:
52
帖 子:5023
专家分:14003
注 册:2016-10-22
第
4
楼
得分:10
回复 楼主 renkejun1942
类似于广度搜索~按层遍历不行么~你的迭代版的按层遍历都出来了~用队列处理应该不难~
[code]/*~个性签名:bug是什么意思?bug是看上去没有可能的东西实际上是有可能做到的 就是这样~2018-08-08更~*/[/code]
2017-05-13 23:23
renkejun1942
来 自:不是这样
等 级:
贵宾
威 望:
33
帖 子:1645
专家分:5297
注 册:2016-12-1
第
5
楼
得分:0
回复 4楼 九转星河
唔……层次遍历,最后一个进入队列的节点,必然比其他节点深。。。。
so……计算最后一个节点的深度就可以了。。。
我想想想想想想想想想想先……
[此贴子已经被作者于2017-5-13 23:29编辑过]
09:30 05/21 种下琵琶种子,能种活么?等待中……
21:50 05/27 没有发芽。
20:51 05/28 没有发芽。
23:03 05/29 没有发芽。
23:30 06/09 我有预感,要发芽了。
2017-05-13 23:26
renkejun1942
来 自:不是这样
等 级:
贵宾
威 望:
33
帖 子:1645
专家分:5297
注 册:2016-12-1
第
6
楼
得分:0
唔……算是搞定了。
写的很烂,代码几乎直接复制的层次遍历和前序遍历来完成树的高度计算和叶节点数计算。
以后找时间来重写吧,先就这样。
09:30 05/21 种下琵琶种子,能种活么?等待中……
21:50 05/27 没有发芽。
20:51 05/28 没有发芽。
23:03 05/29 没有发芽。
23:30 06/09 我有预感,要发芽了。
2017-05-13 23:58
6
1/1页
1
参与讨论请移步原网站贴子:
https://bbs.bccn.net/thread-476981-1-1.html
关于我们
|
广告合作
|
编程中国
|
清除Cookies
|
TOP
|
手机版
编程中国
版权所有,并保留所有权利。
Powered by
Discuz
, Processed in 0.480569 second(s), 7 queries.
Copyright©2004-2025, BCCN.NET, All Rights Reserved