力扣114. 二叉树展开为链表(java,用树模拟链表)

Problem: 114. 二叉树展开为链表

文章目录

题目描述

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

1.展开后的单链表应该同样使用 TreeNode ,其中 right 子指针指向链表中下一个结点,而左子指针始终为 null 。

2/展开后的单链表应该与二叉树 先序遍历 顺序相同。


思路

我们易知,树与链表两种数据结构都可以通过指针操作 来实现,换一句说两种数据结构都可以归结为一种链式数据结构 只不过一般情况下,一般普通链表每一个节点后都只有一个next指针 ;一般的二叉树每个节点后都会有两个指针left指针和right指针,所以我们即可想到使用一个树来模拟实现链表!!!

1.创建虚拟头节点和尾指针,尾指针初始化指向虚拟头节点。

2.每次遍历过程中将上一节点的right指针指向当前节点,上一节点的left指针置为null

解题方法

1.创建虚拟头节点和尾指针,尾指针初始化指向虚拟头节点。

2.编写辅助的前序遍历函数,每次先取出当前节点的左右子树,再将每次按先序遍历的到的节点添加到尾指针后

复杂度

时间复杂度:

O ( n ) O(n) O(n)

空间复杂度:

O ( 1 ) O(1) O(1)

Code

java 复制代码
/**
 * 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 {
    //创建虚拟头节点
    private TreeNode dummyHead = new TreeNode();
    //创建尾指针
    private TreeNode tail = dummyHead;

    /**
     * 将一个二叉树展开为一个单链表
     *
     * @param root 树的根节点
     */
    public void flatten(TreeNode root) {
        preOrder(root);
    }

    /**
     * 先序遍历,将每次遍历到的节点添加到链表中
     *
     * @param root 树的根节点
     */
    private void preOrder(TreeNode root) {
        if (root == null) {
            return;
        }
        //先取出当前节点的左右节点
        TreeNode leftNode = root.left;
        TreeNode rightNode = root.right;
        //把遍历到的节点放在链表中
        tail.right = root;
        tail = root;
        tail.left = null;

        preOrder(leftNode);
        preOrder(rightNode);
    }

}
相关推荐
无心水1 分钟前
【分布式利器:腾讯TSF】10、TSF故障排查与架构评审实战:Java架构师从救火到防火的生产哲学
java·人工智能·分布式·架构·限流·分布式利器·腾讯tsf
Boilermaker19927 小时前
[Java 并发编程] Synchronized 锁升级
java·开发语言
Cherry的跨界思维7 小时前
28、AI测试环境搭建与全栈工具实战:从本地到云平台的完整指南
java·人工智能·vue3·ai测试·ai全栈·测试全栈·ai测试全栈
alonewolf_998 小时前
JDK17新特性全面解析:从语法革新到模块化革命
java·开发语言·jvm·jdk
一嘴一个橘子8 小时前
spring-aop 的 基础使用(啥是增强类、切点、切面)- 2
java
sheji34168 小时前
【开题答辩全过程】以 中医药文化科普系统为例,包含答辩的问题和答案
java
恋爱绝缘体19 小时前
2020重学C++重构你的C++知识体系
java·开发语言·c++·算法·junit
wszy18099 小时前
新文章标签:让用户一眼发现最新内容
java·python·harmonyos
wszy18099 小时前
顶部标题栏的设计与实现:让用户知道自己在哪
java·python·react native·harmonyos
程序员小假10 小时前
我们来说一下无锁队列 Disruptor 的原理
java·后端