LeetCode:随机链表的复制

java 复制代码
/*
// Definition for a Node.
class Node {
    int val;
    Node next;
    Node random;

    public Node(int val) {
        this.val = val;
        this.next = null;
        this.random = null;
    }
}
*/

class Solution {
    public Node copyRandomList(Node head) {
        //null判断
        if(head  == null){
            return null;
        }
        //制造分身
        Node curr = head;
        while(curr != null){
            Node clone = new Node(curr.val);
            clone.next = curr.next;
            curr.next = clone;
            curr = clone.next;
        }
        //复制random指针
        curr = head;
        while(curr != null){
            if(curr.random != null){
                curr.next.random = curr.random.next;
            }
            curr = curr.next.next;
        }
        //分离链表
        curr = head;
        Node cloneHead = head.next;
        Node cloneCurr = cloneHead;
        while(curr != null){
            curr.next = curr.next.next;

            if(cloneCurr.next != null){
                cloneCurr.next = cloneCurr.next.next;
            }

            curr = curr.next;
            cloneCurr = cloneCurr.next;
        }
        return cloneHead;
    }
}

先复制一份相同的节点,指向为A->A'->B->B';

然后将random指针也复制一份;

最后将两组指针进行分离。

相关推荐
z200509305 小时前
每日简单算法题——————跟着卡尔
算法
️是786 小时前
信息奥赛一本通—编程启蒙(3395:练68.3 车牌问题)
数据结构·c++·算法
Liangwei Lin7 小时前
LeetCode 118. 杨辉三角
算法·leetcode·职场和发展
计算机安禾7 小时前
【c++面向对象编程】第24篇:类型转换运算符:自定义隐式转换与explicit
java·c++·算法
鼠鼠我(‘-ωก̀ )好困7 小时前
leetGPU
算法
我星期八休息7 小时前
Linux系统编程—基础IO
linux·运维·服务器·c语言·c++·人工智能·算法
池塘的蜗牛7 小时前
A Low-Complexity Method for FFT-based OFDM Sensing
算法
故事和你918 小时前
洛谷-【图论2-1】树5
开发语言·数据结构·c++·算法·动态规划·图论
咖啡里的茶i8 小时前
视觉显著目标的自适应分割与动态网格生成算法研究
人工智能·算法·目标跟踪
paeamecium8 小时前
【PAT甲级真题】- String Subtraction (20)
数据结构·c++·算法·pat考试·pat