LeetCode 103 二叉樹的鋸齒形層次遍歷

2021-10-23 17:01:11 字數 1032 閱讀 5727

題目描述

給定乙個二叉樹,返回其節點值的鋸齒形層次遍歷。(即先從左往右,再從右往左進行下一層遍歷,以此類推,層與層之間交替進行)。

例如:給定二叉樹 [3,9,20,null,null,15,7],

3

/ \ 9

20/ \157

返回鋸齒形層次遍歷如下:

[[3

],[20

,9],

[15,7

]]

解題思路

可以採用遞迴的方式來解答,每一層都建立乙個陣列,奇數層從左往右依次插入陣列,偶數層從右往左依次插入陣列。

思路不是很難,這裡我們使用i & 1來判斷層數的奇偶:

i &1==

1// 奇數

i &1==0

// 偶數

該方法的時間複雜度為o(n)空間複雜度為o(n)

**實現

/**

* definition for a binary tree node.

* function treenode(val)

*//**

* @param root

* @return

*/var

zigzaglevelorder

=function

(root)

if(i &1)

else

dfs(i +

1, current.left)

dfs(i +

1, current.right)

}dfs(0

, root)

return res

};

提交結果

leetcode 103二叉樹的鋸形遍歷

方法 使用棧和佇列。1 首先判斷二叉樹是否為空 建立res,和queue有兩個引數,第乙個是節點,第二個是層數。將根節點放入,開始迴圈。2 len是這一層的節點數,level是層數,如果當前res的大小等於level建立。3 開始迴圈當前層數的節點,首先判斷層數是奇數還是偶數,偶數直接進入res,奇...

Leetcode 103 二叉樹的鋸齒形層次遍歷

給定乙個二叉樹,返回其節點值的鋸齒形層次遍歷。即先從左往右,再從右往左進行下一層遍歷,以此類推,層與層之間交替進行 例如 給定二叉樹 3,9,20,null,null,15,7 3 9 20 15 7 返回鋸齒形層次遍歷如下 3 20,9 15,7 解題思路 解題的大致思路是廣度優先搜尋的思路,但有...

leetcode 103 二叉樹的鋸齒形層次遍歷

給定乙個二叉樹,返回其節點值的鋸齒形層次遍歷。即先從左往右,再從右往左進行下一層遍歷,以此類推,層與層之間交替進行 例如 給定二叉樹 3,9,20,null,null,15,7 3 9 20 15 7返回鋸齒形層次遍歷如下 3 20,9 15,7 題意要求實現每遍歷一層就反序一次,可以用兩個棧,遍歷...