Problem
Given a binary tree, flatten it to a linked list in-place.
For example, given the following tree:
1
/ \
2 5
/ \ \
3 4 6
The flattened tree should look like:
1
\
2
\
3
\
4
\
5
\
6
问题
给定一个二叉树,原地将它展开为一个单链表。
例如,给定二叉树
1
/ \
2 5
/ \ \
3 4 6
将其展开为:
1
\
2
\
3
\
4
\
5
\
6
思路
递归
1. 先将左右子树拉平成链表
2. 再把左子树作为新的右子树
3. 最后把原先右子树接到当前右子树末端
Python3 代码
# Definition for a binary tree node.
# class TreeNode:
# def __init__(self, val=0, left=None, right=None):
# self.val = val
# self.left = left
# self.right = right
class Solution:
def flatten(self, root: TreeNode) -> None:
"""
Do not return anything, modify root in-place instead.
"""
if not root:
return
# 递归调用
self.flatten(root.left)
self.flatten(root.right)
# 后序遍历:左-右-根
# 左右子树拉平成链表
left = TreeNode()
left = root.left
right = TreeNode()
right = root.right
# 左子树作为右子树
root.left = None
root.right = left
# 原先右子树接到当前右子树末端
p = TreeNode()
p = root
# 找到当前右子树末端
while p.right != None:
p = p.right
p.right = right
Go 代码
/**
* Definition for a binary tree node.
* type TreeNode struct {
* Val int
* Left *TreeNode
* Right *TreeNode
* }
*/
func flatten(root *TreeNode) {
if root == nil {
return
}
// 递归调用
flatten(root.Left)
flatten(root.Right)
// 后序遍历:左-右-根
// 左右子树拉平成链表
var left = new(TreeNode)
left = root.Left
var right = new(TreeNode)
right = root.Right
// 左子树作为右子树
root.Left = nil
root.Right = left
// 原先右子树接到当前右子树末端
var p = new(TreeNode)
p = root
// 找到当前右子树末端
for {
if p.Right == nil {
break
}
p = p.Right
}
p.Right = right
}
GitHub 链接
Problem
Given a binary tree, flatten it to a linked list in-place.
For example, given the following tree:
1
/ \
2 5
/ \ \
3 4 6
The flattened tree should look like:
1
\
2
\
3
\
4
\
5
\
6
问题
给定一个二叉树,原地将它展开为一个单链表。
例如,给定二叉树
1
/ \
2 5
/ \ \
3 4 6
将其展开为:
1
\
2
\
3
\
4
\
5
\
6
思路
递归
1. 先将左右子树拉平成链表
2. 再把左子树作为新的右子树
3. 最后把原先右子树接到当前右子树末端
Python3 代码
# Definition for a binary tree node.
# class TreeNode:
# def __init__(self, val=0, left=None, right=None):
# self.val = val
# self.left = left
# self.right = right
class Solution:
def flatten(self, root: TreeNode) -> None:
"""
Do not return anything, modify root in-place instead.
"""
if not root:
return
# 递归调用
self.flatten(root.left)
self.flatten(root.right)
# 后序遍历:左-右-根
# 左右子树拉平成链表
left = TreeNode()
left = root.left
right = TreeNode()
right = root.right
# 左子树作为右子树
root.left = None
root.right = left
# 原先右子树接到当前右子树末端
p = TreeNode()
p = root
# 找到当前右子树末端
while p.right != None:
p = p.right
p.right = right
Go 代码
/**
* Definition for a binary tree node.
* type TreeNode struct {
* Val int
* Left *TreeNode
* Right *TreeNode
* }
*/
func flatten(root *TreeNode) {
if root == nil {
return
}
// 递归调用
flatten(root.Left)
flatten(root.Right)
// 后序遍历:左-右-根
// 左右子树拉平成链表
var left = new(TreeNode)
left = root.Left
var right = new(TreeNode)
right = root.Right
// 左子树作为右子树
root.Left = nil
root.Right = left
// 原先右子树接到当前右子树末端
var p = new(TreeNode)
p = root
// 找到当前右子树末端
for {
if p.Right == nil {
break
}
p = p.Right
}
p.Right = right
}