「leetCode」114-二叉树展开为链表⚡️

简介: 「leetCode」114-二叉树展开为链表⚡️

image.png

题目🦀


114. 二叉树展开为链表


难度中等


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

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


示例 1:


image.png

输入: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]

提示:


  • 树中结点数在范围 [0, 2000]
  • -100 <= Node.val <= 100

**进阶:**你可以使用原地算法(O(1) 额外空间)展开这棵树吗?


解题思路🌵


  • 先进行前序遍历,遍历出各个节点
  • 然后将节点依次放书数组中
  • 最后遍历数组,拼接链表


解题步骤🐂


  • 初始化list数组用来存放结点
  • 进行先序遍历,存放结点
  • 遍历结点,拼接为链表


源码🔥


/**
 * Definition for a binary tree node.
 * function TreeNode(val, left, right) {
 *     this.val = (val===undefined ? 0 : val)
 *     this.left = (left===undefined ? null : left)
 *     this.right = (right===undefined ? null : right)
 * }
 */
/**
 * @param {TreeNode} root
 * @return {void} Do not return anything, modify root in-place instead.
 */
var flatten = function(root) {
        let list = []
        preTravel(root,list)
        for(let i=1;i<list.length;i++){
            const pre = null;
            const cur = list[i]
            list[i-1].left=pre;
            list[i-1].right=cur
        }
};
function preTravel(root,list){
    if(root){
        list.push(root)
        preTravel(root.left,list)
        preTravel(root.right,list)
    }
}

时间复杂度:O(n)


空间复杂度:O(n)


结束语🌞


image.png


那么鱼鱼的LeetCode算法篇的「leetCode」114-二叉树展开为链表⚡️就结束了,算法这个东西没有捷径,只能多写多练,多总结,文章的目的其实很简单,就是督促自己去完成算法练习并总结和输出,菜不菜不重要,但是热爱🔥,喜欢大家能够喜欢我的短文,也希望通过文章认识更多志同道合的朋友,如果你也喜欢折腾,欢迎加我好友,一起沙雕,一起进步


相关文章
|
5月前
|
存储 SQL 算法
LeetCode力扣第114题:多种算法实现 将二叉树展开为链表
LeetCode力扣第114题:多种算法实现 将二叉树展开为链表
|
6月前
leetcode-114:二叉树展开为链表
leetcode-114:二叉树展开为链表
44 0
|
算法
代码随想录算法训练营第二十一天 | LeetCode 235. 二叉搜索树的最近公共祖先、701. 二叉搜索树中的插入操作、450. 删除二叉搜索树中的节点
代码随想录算法训练营第二十一天 | LeetCode 235. 二叉搜索树的最近公共祖先、701. 二叉搜索树中的插入操作、450. 删除二叉搜索树中的节点
61 0
|
存储 算法
图解LeetCode——114. 二叉树展开为链表
图解LeetCode——114. 二叉树展开为链表
11210 1
图解LeetCode——114. 二叉树展开为链表
|
Sentinel
力扣19删除链表的倒数第 N 个结点:思路分析+图文全解+方法总结(快慢指针法&递归法)+深入思考
力扣19删除链表的倒数第 N 个结点:思路分析+图文全解+方法总结(快慢指针法&递归法)+深入思考
169 0
|
算法
LeetCode 114. 二叉树展开为链表
LeetCode 114. 二叉树展开为链表
150 0
LeetCode 114. 二叉树展开为链表
|
算法
「leetCode」114-二叉树展开为链表⚡️
「leetCode」114-二叉树展开为链表⚡️
118 0
「leetCode」114-二叉树展开为链表⚡️
|
算法 前端开发 程序员
「LeetCode」707-设计链表⚡️
「LeetCode」707-设计链表⚡️
124 0
「LeetCode」707-设计链表⚡️
|
算法 前端开发 程序员
「LeetCode」剑指Offer-54二叉搜索树的第k大节点⚡️
「LeetCode」剑指Offer-54二叉搜索树的第k大节点⚡️
105 0
「LeetCode」剑指Offer-54二叉搜索树的第k大节点⚡️
|
算法 前端开发 程序员
「LeetCode」剑指Offer-18删除链表的节点⚡️
「LeetCode」剑指Offer-18删除链表的节点⚡️
87 0
「LeetCode」剑指Offer-18删除链表的节点⚡️