算法--二叉树展开

news/发布时间2024/5/13 20:28:19

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]

展开的顺序是二叉树的先序遍历的顺序。 把左子树不断的插入到右子树,原来的右子树放嫁接过来的左子树的最右边。

public void flatten(TreeNode root) {while (root != null) { //左子树为 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;}}
} 
考虑把左子树嫁接到右子树,让原来的右子树接到左子树最后。不断的递归最终完成先序遍历的同时完成了单链表的构建。
 if (root.left == null) {root = root.right;
考虑root当前的左子树是否为null,如果为null,就只能遍历右边。根节点出发,左子树没有,右子树也可能出现需要把右子树的左孩子拼到右侧的情况

 // 找左子树最右边的节点TreeNode pre = root.left;while (pre.right != null) {pre = pre.right;} 
在这里,保存左子树的节点pre. 如果左子树有右孩子,就保存左子树的右孩子为pre。 这里保留pre是为了让root节点的右子树拼到root节点的左子树的后面。

//将原来的右子树接到左子树的最右边节点pre.right = root.right;// 将左子树插入到右子树的地方
右子树拼到左子树的pre节点(要连接root右子树的节点)的右孩子节点。
root.right = root.left;
左子树插入到右子树的地方,这时候,右子树的节点断开。

root.left = null;
清空右子树的节点。
// 考虑下一个节点。root节点的下一个右节点作为root节点依次递归下去。 root = root.right;

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.ulsteruni.cn/article/14886706.html

如若内容造成侵权/违法违规/事实不符,请联系编程大学网进行投诉反馈email:xxxxxxxx@qq.com,一经查实,立即删除!

相关文章

软工作业2:个人项目

软工作业2:论文查重 github仓库地址:https://github.com/Chynsh/Chynsh/tree/main/3121005252/Paperchecker 作业要求这个作业属于哪个课程 软件工程这个作业要求在哪里 个人项目这个作业的目标 设计一个论文查重算法,在答案文件中输出其重复率。PSP表记录PSP2.1 Personal S…

C#通过SQLiteDataReader读取GBK(gb2312)格式的SqLite数据库

正常情况下,C#通过SQLiteDataReader读SqLite数据库,不论读写都是采用的uft-8格式编码。 但是我在搞QQ群机器人(Mirai)的时候,遇到了读取以前旧版本机器人数据库的情况。旧片机器人是采用java或者C++程序写的,存取时的编码是GBK(gb2312),然后在原来的程序里面打开和编辑…

软件工程-个人项目

github地址 GitHub PSP表格PSP2.1 Personal Software Process Stages 预估耗时(分钟) 实际耗时(分钟)Planning 计划 40 30 Estimate估计这个任务需要多少时间 1500 1500Development 开发 420 400 Analysis需求分析 (包括学习新技术) 180 150 Design Spec生成设计文档 60 …

9.15课堂验证(已在文件发表)

TestDouble: 源代码: public class TestDouble { public static void main(String args[]) {System.out.println("0.05 + 0.01 = " + (0.05 + 0.01));System.out.println("1.0 - 0.42 = " + (1.0 - 0.42));System.out.println("4.015 * 100 = &qu…

DVWA靶场通关-File Upload(文件上传)

Brute Force(暴力(破解))、Command Injection(命令行注入)、CSRF(跨站请求伪造)、 File Inclusion(文件包含)、File Upload(文件上传)、Insecure CAPTCHA (不安全的验证码)、 SQL Injection(SQL注入)、SQL Injection(Blind)(SQL盲注)、XSS(…

使用nssm将frpc安装为windows服务

在Windows 中配置启动项仅是在用户登录后运行。在登录前要启动就需要将其配置为“服务”。 简介: 之前介绍过如何使用frp进行端口转发和二级域名自定义,方便公司进行统一管理和监控。 但在实际生产过程中,开发人员发现frpc的窗口为应用窗口,极易出现误操作而关闭应用窗口,…