Leetcode--Java--430. 扁平化多级双向链表

2023-12-02 18:48

本文主要是介绍Leetcode--Java--430. 扁平化多级双向链表,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

题目描述

在这里插入图片描述

样例描述

在这里插入图片描述

思路

方法一:递归 + 迭代 O(n^2)

  1. 没孩子结点就一直next,如果有孩子结点,就先存储当前结点的下一个,然后不断递归(将孩子部分先展平),随后拼接当前结点和展平后的部分,并将当前结点的孩子指针设置为null,然后寻找展平部分的最后一个结点与原始当前结点的下一个结点进行拼接。 最后将当前结点设置为原始的下一个,准备下一轮迭代。

方法二:对方法一的优化:额外写递归函数 O(n)

  1. 方法一中由于每次是从head.child开始递归,又要每一次再次遍历寻找展平部分的尾结点。这里最坏情况复杂度是平方。
  2. 单独写递归函数,每次直接返回展平后的"尾结点",使得找尾结点的部分不会在每一层出现,可以达到O(n)
    递归拼接顺序如下:
    在这里插入图片描述

方法三: 迭代
迭代的拼接顺序与递归不同,是一段一段进行的,区别如下:
在这里插入图片描述

  1. 让head从最开始一直走,只要child不为空,就先迭代拼接处理完child层,然后继续往后,碰到有child就拼接。(虽然head会越遍历越长,因为不断拼接了child层,但是对每个结点只会访问常数次)

代码

方法一:

/*
// Definition for a Node.
class Node {public int val;public Node prev;public Node next;public Node child;
};
*/class Solution {public Node flatten(Node head) {     Node dummy = new Node(-1);dummy.next = head;while (head != null) {if (head.child == null) {head = head.next;} else {//先存下当前的下一个结点Node nextN = head.next;//递归不断地展平,得到展平后的第一个结点Node flatnode = flatten(head.child);//将当前结点与展平后那块链表进行拼接head.next = flatnode;flatnode.prev = head;//这里要让孩子指针为null,因为上面已经展平head.child = null;//寻找展平后的最后一个结点,与原始head的下一个结点进行拼接 (也就是融入head所在层)while (head.next != null) {head = head.next;}head.next = nextN;//这里一定要判断下是否为null,不然空会有异常if (nextN != null)nextN.prev = head;//然后让head更新为next,准备下一轮迭代head = nextN;}}return dummy.next;}
}

方法二:优化递归

/*
// Definition for a Node.
class Node {public int val;public Node prev;public Node next;public Node child;
};
*/class Solution {public Node flatten(Node head) {dfs(head);return head;}//返回展平后的尾结点,返回给上一层使用public Node dfs(Node head) {Node last = head;while (head != null) {if (head.child == null) {last = head;head = head.next;} else {Node nextN = head.next;Node lastChild = dfs(head.child);//拼接head以及head的下一个head.next = head.child;head.child.prev = head;//孩子指针设置为空head.child = null;//让最后一个和上层head的下一个拼接lastChild.next = nextN;if (nextN != null) {nextN.prev = lastChild;}//准备下一轮,到最后一个  不能到nextNhead = lastChild;}}return last;}
}

方法三:

/*
// Definition for a Node.
class Node {public int val;public Node prev;public Node next;public Node child;
};
*/class Solution {public Node flatten(Node head) {Node dummy = new Node(-1);dummy.next = head;while (head != null) {//有孩子if (head.child != null) {Node t = head.next;Node child = head.child;head.next = child;child.prev = head;head.child = null;//迭代找尾结点Node last = child;while (last.next != null) {last = last.next;}last.next = t;if (t != null) {t.prev = last;}} head = head.next;}return dummy.next;}
}

这篇关于Leetcode--Java--430. 扁平化多级双向链表的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/446408

相关文章

Java反转字符串的五种方法总结

《Java反转字符串的五种方法总结》:本文主要介绍五种在Java中反转字符串的方法,包括使用StringBuilder的reverse()方法、字符数组、自定义StringBuilder方法、直接... 目录前言方法一:使用StringBuilder的reverse()方法方法二:使用字符数组方法三:使用自

JAVA封装多线程实现的方式及原理

《JAVA封装多线程实现的方式及原理》:本文主要介绍Java中封装多线程的原理和常见方式,通过封装可以简化多线程的使用,提高安全性,并增强代码的可维护性和可扩展性,需要的朋友可以参考下... 目录前言一、封装的目标二、常见的封装方式及原理总结前言在 Java 中,封装多线程的原理主要围绕着将多线程相关的操

Java进阶学习之如何开启远程调式

《Java进阶学习之如何开启远程调式》Java开发中的远程调试是一项至关重要的技能,特别是在处理生产环境的问题或者协作开发时,:本文主要介绍Java进阶学习之如何开启远程调式的相关资料,需要的朋友... 目录概述Java远程调试的开启与底层原理开启Java远程调试底层原理JVM参数总结&nbsMbKKXJx

Spring Cloud之注册中心Nacos的使用详解

《SpringCloud之注册中心Nacos的使用详解》本文介绍SpringCloudAlibaba中的Nacos组件,对比了Nacos与Eureka的区别,展示了如何在项目中引入SpringClo... 目录Naacos服务注册/服务发现引⼊Spring Cloud Alibaba依赖引入Naco编程s依

java导出pdf文件的详细实现方法

《java导出pdf文件的详细实现方法》:本文主要介绍java导出pdf文件的详细实现方法,包括制作模板、获取中文字体文件、实现后端服务以及前端发起请求并生成下载链接,需要的朋友可以参考下... 目录使用注意点包含内容1、制作pdf模板2、获取pdf导出中文需要的文件3、实现4、前端发起请求并生成下载链接使

Java springBoot初步使用websocket的代码示例

《JavaspringBoot初步使用websocket的代码示例》:本文主要介绍JavaspringBoot初步使用websocket的相关资料,WebSocket是一种实现实时双向通信的协... 目录一、什么是websocket二、依赖坐标地址1.springBoot父级依赖2.springBoot依赖

如何用java对接微信小程序下单后的发货接口

《如何用java对接微信小程序下单后的发货接口》:本文主要介绍在微信小程序后台实现发货通知的步骤,包括获取Access_token、使用RestTemplate调用发货接口、处理AccessTok... 目录配置参数 调用代码获取Access_token调用发货的接口类注意点总结配置参数 首先需要获取Ac

Java逻辑运算符之&&、|| 与&、 |的区别及应用

《Java逻辑运算符之&&、||与&、|的区别及应用》:本文主要介绍Java逻辑运算符之&&、||与&、|的区别及应用的相关资料,分别是&&、||与&、|,并探讨了它们在不同应用场景中... 目录前言一、基本概念与运算符介绍二、短路与与非短路与:&& 与 & 的区别1. &&:短路与(AND)2. &:非短

Java的volatile和sychronized底层实现原理解析

《Java的volatile和sychronized底层实现原理解析》文章详细介绍了Java中的synchronized和volatile关键字的底层实现原理,包括字节码层面、JVM层面的实现细节,以... 目录1. 概览2. Synchronized2.1 字节码层面2.2 JVM层面2.2.1 ente

什么是 Java 的 CyclicBarrier(代码示例)

《什么是Java的CyclicBarrier(代码示例)》CyclicBarrier是多线程协同的利器,适合需要多次同步的场景,本文通过代码示例讲解什么是Java的CyclicBarrier,感... 你的回答(口语化,面试场景)面试官:什么是 Java 的 CyclicBarrier?你:好的,我来举个例