给定一个二叉树,返回其节点值的锯齿形层次遍历。(即先从左往右,再从右往左进行下一层遍历,以此类推,层与层之间交替进行)。
例如:
给定二叉树 [3,9,20,null,null,15,7]
,
3 / \ 9 20 / \ 15 7
返回锯齿形层次遍历如下:
[ [3], [20,9], [15,7] ]
Review:
正常add,最后将得到的index为奇数的集合翻转即可
Code:
class Solution {
public List<List<Integer>> zigzagLevelOrder(TreeNode root) {
List<List<Integer>> res = new ArrayList<>();
helper(res, root, 0, true);
return res;
}
private void helper(List<List<Integer>> res, TreeNode root, int i, boolean flag) {
if (root != null) {
if (res.size() > i) {
res.get(i).add(root.val);
} else {
List<Integer> list = new ArrayList<>();
list.add(root.val);
res.add(list);
}
i++;
if (flag){
helper(res,root.right,i,false);
helper(res,root.left,i,false);
}else {
helper(res,root.left,i,true);
helper(res,root.right,i,true);
}
}
}
}