二叉树打印

二叉树按照宽度优先遍历就是使用队列进行,具体在图解算法中有讲解。

如果要按照行来打印二叉树,需要多加入一个last、和next_last变量。

如上图二叉树。定义last为目前行的最右节点,定义next_last为下一行的最右节点。因此每次打印到last时换行,再更新last和next_last,就可以实现按行打印二叉树。

具体:
1.令last等于节点1,1入队
2.1出队打印,1的子节点2入队,next_last指向2;1的子节点3入队,next_last指向3.(next_last永远指向最新入队的节点)
3.打印的1与last的值相等则换行,last = next_last
4.2出队打印,2的子节点4入队,next_last指向4
5.打印的2与last的值不相等则不换行,继续出队打印下一节点。
6….循环执行以上步骤。


  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值