当前位置: 首页 > news >正文

LeetCode--HOT100题(46)

目录

  • 题目描述:114. 二叉树展开为链表(中等)
    • 题目接口
    • 解题思路
    • 代码
  • PS:

题目描述:114. 二叉树展开为链表(中等)

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

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

LeetCode做题链接:LeetCode-二叉树展开为链表

示例 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]

提示:

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

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

题目接口

/*** Definition for a binary tree node.* public class TreeNode {*     int val;*     TreeNode left;*     TreeNode right;*     TreeNode() {}*     TreeNode(int val) { this.val = val; }*     TreeNode(int val, TreeNode left, TreeNode right) {*         this.val = val;*         this.left = left;*         this.right = right;*     }* }*/
class Solution {public void flatten(TreeNode root) {}
}

解题思路

主要的思路是通过调整树的节点连接,将二叉树展开为一个链表。具体步骤如下:

  1. 从根节点开始,检查左子树是否为空。
  2. 如果左子树为空,则将根节点更新为其右子节点,继续处理下一个节点。
  3. 如果左子树不为空,找到左子树中最右边的节点。
  4. 将原来的右子树接到左子树的最右边节点,这样就将左子树的最深节点移动到了最右边。
  5. 将左子树插入到右子树的位置,即将左子树的最深节点作为新的根节点。
  6. 重复以上步骤,直到处理完所有节点。

通过这样的操作,我们可以将二叉树展开为一个由左子树的节点组成的链表,其中每个节点都包含左子树中的所有节点值。

代码

/*** Definition for a binary tree node.* public class TreeNode {*     int val;*     TreeNode left;*     TreeNode right;*     TreeNode() {}*     TreeNode(int val) { this.val = val; }*     TreeNode(int val, TreeNode left, TreeNode right) {*         this.val = val;*         this.left = left;*         this.right = right;*     }* }*/
class Solution {public void flatten(TreeNode root) {while (root != null) { // 如果左子树为空,直接处理下一个节点if (root.left == null) {root = root.right;} else {// 找到左子树中最右边的节点TreeNode pre = root.left;while (pre.right != null) {pre = pre.right;} // 将原来的右子树接到左子树的最右边节点pre.right = root.right;// 将左子树插入到右子树的位置root.right = root.left;root.left = null;// 处理下一个节点root = root.right;}}
}

成功!
在这里插入图片描述

PS:

感谢您的阅读!如果您觉得本篇文章对您有所帮助,请给予博主一个喔~

http://www.lryc.cn/news/148267.html

相关文章:

  • 深度探索JavaScript中的原型链机制
  • 一种基于WinDump自动抓包实现方法
  • taro 支付宝/微信小程序/h5 上传 - base64的那些事儿
  • java之SpringBoot基础、前后端项目、MyBatisPlus、MySQL、vue、elementUi
  • Vue-Router 一篇搞定 Vue3
  • 深度解读智能媒体服务的重组和进化
  • 亲测有效!Win7中如何安装高版本的NodeJS
  • Python基础__with open()用法
  • 深入理解 JavaScript 对象、属性、解构和增强语法
  • 2023年IT服务行业研究报告
  • 腾讯云服务器镜像TencentOS Server有用过的吗?
  • 小区村庄集中生活废水处理设备厂家直销价格
  • Redisson实现分布式锁案例
  • Generated Knowledge Prompting for Commonsense Reasoning
  • mybatisPlus多数据源方案
  • MonoDETR: Depth-guided Transformer for Monocular 3D Object Detection 论文解读
  • Vulnhub内网渗透DC-7靶场通关
  • acunetix2023安装教程
  • pytest pytest.ini 配置日志输出至文件
  • Linux脚本-将当前文件夹下所有包含main函数的.c文件提取出来
  • Spring依赖注入(DI)
  • 论文笔记: 深度学习速度模型构建的层次迁移学习方法 (未完)
  • 苹果为 Vision Pro 头显申请游戏手柄专利
  • 【数据结构】多叉树转换为二叉树-c++代码实现-POJ 3437 Tree Grafting
  • ASP.NET Core 中基于 Controller 的 Web API
  • iOS系统修复软件 Fix My iPhone for Mac
  • Git企业开发控制理论和实操-从入门到深入(七)|企业级开发模型
  • 15. 卡牌游戏
  • vue使用打印组件print-js
  • 20230830比赛总结