leetcode-114. 二叉树展开为链表

题目描述

给你二叉树的根结点 root ,请你将它展开为一个单链表:

  • 展开后的单链表应该同样使用 TreeNode ,其中 right 子指针指向链表中下一个结点,而左子指针始终为 null
  • 展开后的单链表应该与二叉树 先序遍历 顺序相同。

示例 1:

复制代码
输入:root = [1,2,5,3,4,null,6]
输出:[1,null,2,null,3,null,4,null,5,null,6]

示例 2:

复制代码
输入:root = []
输出:[]

示例 3:

复制代码
输入:root = [0]
输出:[0]

思路

1)先序遍历二叉树到一个list里

2)遍历list,前一个节点为根,后一个节点为右孩子,在置左孩子为None

python 复制代码
# 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 __init__(self):
        self.res = []
    def pretraverse(self, root):
        if not root:
            return None
        self.res.append(root)
        self.pretraverse(root.left)
        self.pretraverse(root.right)
    def flatten(self, root):
        """
        :type root: TreeNode
        :rtype: None Do not return anything, modify root in-place instead.
        """
        self.pretraverse(root)
        for i in range(1, len(self.res)):
            pre,cur = self.res[i-1], self.res[i]
            pre.left = None
            pre.right = cur
        
相关推荐
圣保罗的大教堂24 分钟前
leetcode 1161. 最大层内元素和 中等
leetcode
闲看云起27 分钟前
LeetCode-day6:接雨水
算法·leetcode·职场和发展
没学上了39 分钟前
VLM_一维离散卷积与二维离散卷积(还是复习感觉还行)
算法
黛色正浓1 小时前
leetCode-热题100-贪心合集(JavaScript)
javascript·算法·leetcode
轻微的风格艾丝凡1 小时前
嵌入式定时器计时技巧:用有符号数省略溢出判断的底层逻辑与实践
数据库·算法·dsp开发·嵌入式软件
No0d1es1 小时前
2025年12月 GESP CCF编程能力等级认证C++四级真题
算法·青少年编程·等级考试·gesp·ccf
CodeByV2 小时前
【算法题】快排
算法
一起努力啊~2 小时前
算法刷题--长度最小的子数组
开发语言·数据结构·算法·leetcode
rchmin2 小时前
限流算法:令牌桶与漏桶详解
算法·限流
leoufung2 小时前
LeetCode 221:Maximal Square 动态规划详解
算法·leetcode·动态规划