【队列】按之字形顺序打印二叉树


求解代码

【队列】求二叉树的层序遍历的基础上增加一个flag区分奇偶性就行。

java 复制代码
public ArrayList<ArrayList<Integer>> Print (TreeNode pRoot) {
        ArrayList<ArrayList<Integer>> ans = new ArrayList<>();

		if(pRoot==null){
			return ans;
		}
		Queue<TreeNode> queue = new ArrayDeque<TreeNode>();
		queue.add(pRoot);

		boolean flag = true;

		while(!queue.isEmpty()){
			ArrayList<Integer> list = new ArrayList<>();

			int n = queue.size();

			flag = !flag;

			for(int i=0;i<n;i++){
				TreeNode cur = queue.poll();
				list.add(cur.val);

				if (cur.left!=null) {
					queue.add(cur.left);
				}
				
				if(cur.right!=null){
					queue.add(cur.right);
				}
			}

			if(flag){
				Collections.reverse(list);
			}
			ans.add(list);
		}

		return ans;
    }
相关推荐
洛水水21 小时前
【力扣100题】60.缺失的第一个正数
leetcode·哈希算法
菜菜的顾清寒21 小时前
力扣HOT100(35)回溯-全排列
算法·leetcode·职场和发展
Tisfy1 天前
LeetCode 3121.统计特殊字母的数量 II:状态机
算法·leetcode·题解·状态机
洛水水1 天前
【力扣100题】61.和为 K 的子数组
算法·leetcode·哈希算法
sheeta19981 天前
LeetCode 补拙笔记 日期:2026.05.27 题目:61. 旋转链表
笔记·leetcode·链表
过期动态1 天前
【LeetCode 热题 100】移动零
java·数据结构·算法·leetcode·职场和发展·rabbitmq
菜菜的顾清寒2 天前
力扣HOT100(32)二叉树的中序遍历
数据结构·算法·leetcode
csdn_aspnet2 天前
java 算法 LeetCode 编号 70 - 爬楼梯
java·开发语言·算法·leetcode
_日拱一卒2 天前
LeetCode:200岛屿数量
算法·leetcode·职场和发展
圣保罗的大教堂2 天前
leetcode 153. 寻找旋转排序数组中的最小值 中等
leetcode