Java复杂链表的复制详解

1.题目

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

Java复杂链表的复制详解_第1张图片

Java复杂链表的复制详解_第2张图片

题目来源:力扣(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复杂链表的复制详解_第3张图片

 复制节点

Java复杂链表的复制详解_第4张图片

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

Java复杂链表的复制详解_第5张图片

 拆分成两个链表

Java复杂链表的复制详解_第6张图片

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复杂链表的复制详解_第7张图片

到此这篇关于Java复杂链表的复制详解的文章就介绍到这了,更多相关Java 复杂链表内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

你可能感兴趣的:(Java复杂链表的复制详解)