給定乙個二叉樹,返回其節點值的鋸齒形層次遍歷。(即先從左往右,再從右往左進行下一層遍歷,以此類推,層與層之間交替進行)。
例如:給定二叉樹[3,9,20,null,null,15,7]
,
3返回鋸齒形層次遍歷如下:/ \9 20
/ \
15 7
[渣渣晴分了左右兩邊討論……[3],
[20,9],
[15,7]
]
下一層樹的儲存順序不一樣……
# definition for a binary tree node.
# class treenode:
# def __init__(self, x):
# self.val = x
# self.left = none
# self.right = none
class solution:
def zigzaglevelorder(self, root: treenode) -> list[list[int]]:
if not root:
return
lorr=true #先左
result=
level=[root]
while len(level)>0:
if lorr:#左
num=
temp=
for tree in level:
if tree.left:
temp.insert(0,tree.left)
if tree.right:
temp.insert(0,tree.right)
level=temp
lorr=false
else:#右
num=
temp=
for tree in level:
if tree.right:
temp.insert(0,tree.right)
if tree.left:
temp.insert(0,tree.left)
level=temp
lorr=true
return result
照著大佬的改,不知道為沒他那麼快……總之,按從左到右的順序存數字,再一逆序就好了……渣渣晴哭暈……
# definition for a binary tree node.
# class treenode:
# def __init__(self, x):
# self.val = x
# self.left = none
# self.right = none
class solution:
def zigzaglevelorder(self, root: treenode) -> list[list[int]]:
if not root:
return
lorr=false #先左
result=
level=[root]
while len(level)>0:
num=
temp=
for tree in level:
if tree.left:
if tree.right:
if lorr:#右
else:#左
level=temp
lorr= not lorr
return result
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 題意要求實現每遍歷一層就反序一次,可以用兩個棧,遍歷...