您的位置:首页 > 其它

102、Binary Tree Level Order Traversal

2015-11-26 22:40 246 查看
题目:

Given a binary tree, return the level order traversal of its nodes' values. (ie, from left to right, level by level).

For example:

Given binary tree
{3,9,20,#,#,15,7}
,

3
/ \
9  20
/  \
15   7


return its level order traversal as:

[
[3],
[9,20],
[15,7]
]

解题思路:
二叉树的层次遍历

# Definition for a binary tree node.
# class TreeNode(object):
#     def __init__(self, x):
#         self.val = x
#         self.left = None
#         self.right = None

class Solution(object):
def levelOrder(self, root):
"""
:type root: TreeNode
:rtype: List[List[int]]
"""
def levtrav(q):
tmp = q[:]
for l in tmp:
x = q.pop(0)
if(x.left!=None):
q.append(x.left)
if(x.right!=None):
q.append(x.right)
return q

res,queue = [],[]
if(root):
res.append([root.val])
queue.append(root)
while(len(queue)!=0):
tmp = []
for l in queue:
if(l.left!=None):
tmp.append(l.left.val)
if(l.right!=None):
tmp.append(l.right.val)
if(tmp!=[]):
res.append(tmp)
queue = levtrav(queue[:])
return res
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: