1 Star 0 Fork 0

yuhang2__2/LeetCode-Solutions

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
克隆/下载
find-all-the-lonely-nodes.py 1.31 KB
一键复制 编辑 原始数据 按行查看 历史
# Time: O(n)
# Space: O(h)
# Definition for a binary tree node.
class TreeNode(object):
def __init__(self, val=0, left=None, right=None):
self.val = val
self.left = left
self.right = right
class Solution(object):
def getLonelyNodes(self, root):
"""
:type root: TreeNode
:rtype: List[int]
"""
result = []
stk = [root]
while stk:
node = stk.pop()
if not node:
continue
if node.left and not node.right:
result.append(node.left.val)
elif node.right and not node.left:
result.append(node.right.val)
stk.append(node.right)
stk.append(node.left)
return result
# Time: O(n)
# Space: O(h)
class Solution2(object):
def getLonelyNodes(self, root):
"""
:type root: TreeNode
:rtype: List[int]
"""
def dfs(node, result):
if not node:
return
if node.left and not node.right:
result.append(node.left.val)
elif node.right and not node.left:
result.append(node.right.val)
dfs(node.left, result)
dfs(node.right, result)
result = []
dfs(root, result)
return result
Loading...
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
1
https://gitee.com/yuhang2__2/LeetCode-Solutions.git
git@gitee.com:yuhang2__2/LeetCode-Solutions.git
yuhang2__2
LeetCode-Solutions
LeetCode-Solutions
master

搜索帮助