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

2021-09-02 18:54:27 字數 1134 閱讀 5280

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

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

3

/ \9 20

/ \

15 7

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

[

[3],

[20,9],

[15,7]

]

題意要求實現每遍歷一層就反序一次,可以用兩個棧,遍歷第i層時將這一層的所有子節點放入另乙個棧中,遍歷結束後再遍歷另乙個棧,另乙個棧的所有子節點再放入這個棧中,不斷迴圈,直至所有的節點都被訪問過為止。

注意兩次迴圈進棧的順序是不一樣的。

/**

* definition for a binary tree node.

* public class treenode

* }*/class solution

if(r.right!=null)

if(s1.empty())

}while(!s2.empty())

if(r.left!=null)

if(s2.empty())}}

return res;

}}

還有一種遞迴的解法,當處於第i層時,根據i的奇偶性來判斷這一層是應該從左到右還是從右到左遍歷,若是從左到右就向這一層對應的list中add該節點的值,否則就將該節點的值新增到list的左端,以此實現反序。當層數大於res的大小時,應該為res新增乙個新的arraylist,表示新的一層。

/**

* definition for a binary tree node.

* public class treenode

* }*/class solution

public void dfs(list> res,int level,treenode root)

if(level%2==1)

else

dfs(res,level+1,root.left);

dfs(res,level+1,root.right);

}}

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 渣渣晴分了左右兩邊討論 下一層樹的儲存順序不一樣 d...