Leetcode面试经典150题-138.随机链表的复制

题目比较简单,重点是理解思想,random不管,copy一定要放在next

而且里面的遍历过程不能省略

解法都在代码里,不懂就留言或者私信

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 {
    /**基本思路:1.遍历链表,每个节点拷贝一个节点放到它的next位置,然后它的copy的下一个放它原来的next
    2.把copy的random指针指向原始节点random指针的下一个(因为下一个是random的copy)
    3.拆分链表,把新的链表拷贝出来*/
    public Node copyRandomList(Node head) {
        if(head == null) {
            return null;
        }
        /**遍历链表复制节点并连接 */
        Node cur = head;
        while(cur != null) {
            Node next = cur.next;
            Node curCopy = new Node(cur.val);
            cur.next = curCopy;
            curCopy.next = next;
            cur = next;
        }
        /**设置新节点的random指针*/
        cur = head;
        while(cur != null) {
            /**这里因为存在复制节点并且复制节点肯定放在原始节点的下一个,所以
            cur.next肯定不为空,所以这里不会有空指针的问题*/
            Node next = cur.next.next;
            cur.next.random = cur.random == null? null : cur.random.next;
            cur = next;
        }
        /**断开链接,分离出拷贝链表,这里先把拷贝链表头节点拿出来*/
        Node newHead = head.next;
        /**还是通过从原来的头开始遍历,因为原链表要改next指针 */
        cur = head;
        while(cur != null) {
            /**拿到原来链表中的next,这个next可能为空 */
            Node next = cur.next.next;
            /**这里有可能next是null,要判断,不然会有空指针 */
            cur.next.next = next == null? null : next.next;
            /**指向原来的next */
            cur.next = next;
            /**指针挪到下个节点继续 */
            cur = next;
        }
        return newHead;
        
    }
}
相关推荐
拉不动的猪9 分钟前
刷刷题31(vue实际项目问题)
前端·javascript·面试
LiDAR点云19 分钟前
Matlab中快速查找元素索引号
数据结构·算法·matlab
只会写Bug的程序员22 分钟前
面试之《webpack从输入到输出经历了什么》
前端·面试·webpack
拉不动的猪24 分钟前
刷刷题30(vue3常规面试题)
前端·javascript·面试
CYRUS_STUDIO27 分钟前
安卓逆向魔改版 Base64 算法还原
android·算法·逆向
狂炫一碗大米饭35 分钟前
面试小题:写一个函数实现将输入的数组按指定类型过滤
前端·javascript·面试
CYRUS_STUDIO1 小时前
安卓实现魔改版 Base64 算法
android·算法·逆向
一只_程序媛1 小时前
【leetcode hot 100 142】环形链表Ⅱ
算法·leetcode·链表
Aphasia3111 小时前
Web身份认证与状态管理:Cookie、Session 与 JWT
前端·面试
Luis Li 的猫猫2 小时前
基于MATLAB的冰块变化仿真
开发语言·图像处理·人工智能·算法·matlab