返回顶部
首页 > 资讯 > 精选 >Java复杂链表的示例分析
  • 326
分享到

Java复杂链表的示例分析

2023-06-28 23:06:53 326人浏览 安东尼
摘要

这篇文章将为大家详细讲解有关Java复杂链表的示例分析,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。1.题目请实现 copyRandomList 函数,复制一个复杂链表。在复杂链表中,每个节点除了有一个

这篇文章将为大家详细讲解有关Java复杂链表的示例分析,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。

    1.题目

    请实现 copyRandomList 函数,复制一个复杂链表。在复杂链表中,每个节点除了有一个 next 指针指向下一个节点,还有一个 random 指针指向链表中的任意节点或者 null。

    Java复杂链表的示例分析

    Java复杂链表的示例分析

    题目来源:力扣(LeetCode

    链接:https://leetcode-cn.com/problems/fu-za-lian-biao-de-fu-zhi-lcof

    2.解法

    2.1 拼接+拆分

    首先我们逐个将节点复制并且和原来的链表连起来得新链表;

    然后再构建新链表的random 指向。当访问原节点 cur 的随机指向节点 cur.random 时,对应新节点 cur.next 的随机指向节点为 cur.random.next 

    将得到的新链表之间的复制节点拆分出来连成一个复制链表,拆分成原链表和复制链表。

    链表图

    Java复杂链表的示例分析

     复制节点

    Java复杂链表的示例分析

     将复制节点的random.next 连接起来

    Java复杂链表的示例分析

     拆分成两个链表

    Java复杂链表的示例分析

    3.代码

    class Solution {    public node copyRandomList(Node head) {        if(head == null) {            return null;        }                //1.复制各个链表,并连接        Node cur = head;        while (cur != null) {            //复制            Node prev = new Node(cur.val);            prev.next = cur.next;            //连接            cur.next = prev;            //往后走            cur = prev.next;        }        //2.构建各新节点的random 指向        cur = head;        while (cur != null) {            if (cur.random != null) {                cur.next.random = cur.random.next;            }            cur = cur.next.next;        }        //3.拆分复制的链表        cur = head.next;        Node node = head;        Node nodeNext = head.next;        while (cur.next != null) {            node.next = node.next.next;            cur.next = cur.next.next;            node = node.next;            cur = cur.next;        }        node.next = null;//尾节点        return nodeNext;//返回新链表的头结点    }}

    Java复杂链表的示例分析

    关于“Java复杂链表的示例分析”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,使各位可以学到更多知识,如果觉得文章不错,请把它分享出去让更多的人看到。

    --结束END--

    本文标题: Java复杂链表的示例分析

    本文链接: https://lsjlt.com/news/321401.html(转载时请注明来源链接)

    有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

    猜你喜欢
    • Java复杂链表的示例分析
      这篇文章将为大家详细讲解有关Java复杂链表的示例分析,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。1.题目请实现 copyRandomList 函数,复制一个复杂链表。在复杂链表中,每个节点除了有一个 ...
      99+
      2023-06-28
    • Java中链表的示例分析
      这篇文章将为大家详细讲解有关Java中链表的示例分析,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。题目一 解法class Solution {  &nbs...
      99+
      2023-06-29
    • leetcode链表之分割链表的示例分析
      这篇文章主要介绍了leetcode链表之分割链表的示例分析,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。题目编写程序以 x 为基准分割链表,使得所有小于&...
      99+
      2023-06-19
    • Java之单链表问题的示例分析
      这篇文章给大家分享的是有关Java之单链表问题的示例分析的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。单链表单链表是一种链式存取的数据结构,用一组地址任意的存储单元存放线性表中的数据元素。链表中的数据是以结点来表...
      99+
      2023-06-20
    • Java复杂链表的复制详解
      目录1.题目2.解法2.1 拼接+拆分3.代码1.题目 请实现 copyRandomList 函数,复制一个复杂链表。在复杂链表中,每个节点除了有一个 next 指针指向下一个节点,...
      99+
      2024-04-02
    • JS复杂判断的示例分析
      这篇文章给大家分享的是有关JS复杂判断的示例分析的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。先看一段代码 const onButtonClick1 =&nb...
      99+
      2024-04-02
    • Java链表实例分析
      这篇文章主要介绍了Java链表实例分析的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇Java链表实例分析文章都会有所收获,下面我们一起来看看吧。1、删除值为val的所有节点删除链表中等于给定值val的所有节点。...
      99+
      2023-06-29
    • Redis中链表的示例分析
      这篇文章主要介绍Redis中链表的示例分析,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!1 链表和链表节点的结构1 节点结构节点的结构大概长下边这个样子:那么,把这些节点就连起来就成了这个样子:2 链表结构链表自然除...
      99+
      2023-06-22
    • php中链表的示例分析
      这篇文章将为大家详细讲解有关php中链表的示例分析,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。链表的操作相对顺序表来说就复杂了许多。因为PHP确实已经为我们解决了很多数组操作上的问题,所以我们可以很方便...
      99+
      2023-06-20
    • java算法题解LeetCode35复杂链表的复制实例
      目录题目示例 1:示例 2:示例 3:示例 4:解题思路题目 AC 剑指 Offer 35. 复杂链表的复制请实现 copyRandomList 函数,复制一个复杂链表。在复杂链表中...
      99+
      2023-01-05
      java算法复杂链表复制 java LeetCode
    • Java数据结构之链表的示例分析
      小编给大家分享一下Java数据结构之链表的示例分析,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!一、链表的介绍什么是链表链表是一种物理存储单元上非连续、非顺序的存...
      99+
      2023-06-15
    • 链表原理及java实现的示例分析
      这篇文章主要介绍了链表原理及java实现的示例分析,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。一:单向链表基本介绍链表是一种数据结构,和数组同级。比如,Java中我们使用的...
      99+
      2023-05-30
      java
    • Angular1.x复杂指令的示例分析
      这篇文章主要介绍了Angular1.x复杂指令的示例分析,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。具体如下:名称描述compile指定一...
      99+
      2024-04-02
    • 表链接proc sql的示例分析
      这篇文章给大家分享的是有关表链接proc sql的示例分析的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。 proc sql; select *&nb...
      99+
      2024-04-02
    • python双向链表的示例分析
      小编给大家分享一下python双向链表的示例分析,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!python是什么意思Python是一种跨平台的、具有解释性、编译性...
      99+
      2023-06-14
    • Spring Data Jpa复杂查询的示例分析
      小编给大家分享一下Spring Data Jpa复杂查询的示例分析,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!Spring Data Jpa...
      99+
      2023-06-29
    • Linux中内核链表的示例分析
      这篇文章主要介绍Linux中内核链表的示例分析,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!Linux中的内核链表实例详解链表中一般都要进行初始化、插入、删除、显示、释放链表,寻找节点这几个操作,下面我对这几个操作进...
      99+
      2023-06-09
    • Java时间复杂度与空间复杂度实例分析
      本篇内容主要讲解“Java时间复杂度与空间复杂度实例分析”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Java时间复杂度与空间复杂度实例分析”吧!一、算法效率算法效率分析分为两种:第一种是时间效...
      99+
      2023-06-29
    • Java面试题-实现复杂链表的复制代码分享
      阿里终面在线编程题,写出来与大家分享一下        有一个单向链表,每个节点都包含一个random指针,指向本链表中的某个节点或者为空,写一个深度拷贝函数,拷贝整个链...
      99+
      2023-05-31
      java 链表 ava
    • AngularJS基于MVC复杂操作的示例分析
      这篇文章给大家分享的是有关AngularJS基于MVC复杂操作的示例分析的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。实例如下:<!DOCTYPE html>...
      99+
      2024-04-02
    软考高级职称资格查询
    编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
    • 官方手机版

    • 微信公众号

    • 商务合作