使用单层循环完成树的层次遍历

/**
* 主要思想:主要思想就是使用两个队列一个队列指向上一层,另外一个队列则指向下一层,上层的队列
* 出队时判断其是否存在子节点有则存入下层队列中。当一层遍历结束后下层的队列也就形成了,这时将
* 这时的处理就是将将上层队列下移一层,下层的队列清空重新构建更下层的队列。如此循环往复,直到
* 下层不再有子节点,这时两个队列都是空队列遍历结束
* */
public ArrayList<ArrayList> levelOrder (TreeNode root) {
ArrayList<ArrayList> result = new 、 ArrayList<ArrayList>();
if(root == null){
return result;
}
ArrayDeque queue_1 = new ArrayDeque();
ArrayDeque queue_2 = new ArrayDeque();
queue_1.offer(root);
int level = 0;
ArrayList list = new ArrayList();
while(queue_1.size() != 0 || queue_2.size() != 0) {
TreeNode node = queue_1.pop();
list.add(node.val);
if(node.left != null) {
queue_2.offer(node.left);
}
if(node.right != null) {
queue_2.offer(node.right);
}
if(queue_1.size() == 0) {
queue_1 = queue_2;
queue_2 = new ArrayDeque();
result.add(list);
list = new ArrayList();
}
}
return result;
}

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值