二叉树按照宽度优先遍历就是使用队列进行,具体在图解算法中有讲解。
如果要按照行来打印二叉树,需要多加入一个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….循环执行以上步骤。