剑指:之字形打印二叉树
Posted lisen10
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了剑指:之字形打印二叉树相关的知识,希望对你有一定的参考价值。
题目描述
请实现一个函数按照之字形打印二叉树,即第一行按照从左到右的顺序打印,第二层按照从右至左的顺序打印,第三行按照从左到右的顺序打印,其他行以此类推。
如二叉树:
1
/ 2 3
/ \ / 4 5 6 7
打印结果为:
1
3 2
4 5 6 7
解法
之字形打印,即先从左到右,后从右到左,借助栈结构实现;
两个辅助栈:一个存放奇数层节点的栈s1,一个存放偶数层节点的栈s2。
s1栈中的节点弹出,其节点的 左->右 孩子进s2栈;
s2栈中的节点弹出,其节点的 右->左 孩子进s1栈;
出栈的顺序就是打印的顺序。
import java.util.ArrayList; import java.util.Stack; /* public class TreeNode int val = 0; TreeNode left = null; TreeNode right = null; public TreeNode(int val) this.val = val; */ public class Solution public ArrayList<ArrayList<Integer>> Print(TreeNode pRoot) ArrayList<ArrayList<Integer>> res = new ArrayList<>(); if(pRoot==null) return res; Stack<TreeNode> s1 = new Stack<>(); Stack<TreeNode> s2 = new Stack<>(); s1.push(pRoot); int layer = 1; while(!s1.isEmpty() || !s2.isEmpty()) if(layer%2 != 0) //奇数层 ArrayList<Integer> list = new ArrayList<>(); while(!s1.isEmpty()) TreeNode node = s1.pop(); if(node != null) list.add(node.val); // s2.push(node.left); s2.push(node.right); if(!list.isEmpty()) res.add(list); layer++; else//偶数层 ArrayList<Integer> list = new ArrayList<>(); while(!s2.isEmpty()) TreeNode node = s2.pop(); if(node != null) list.add(node.val); // s1.push(node.right); s1.push(node.left); if(!list.isEmpty()) res.add(list); layer++; return res;
以上是关于剑指:之字形打印二叉树的主要内容,如果未能解决你的问题,请参考以下文章