LeetCode | 0114. 二叉树展开为链表【Python】【Go】

Problem

LeetCode

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

LeetCode

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 链接

posted @ 2021-01-06 21:39  Wonz  阅读(129)  评论(0)    收藏  举报