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;
        
    }
}
相关推荐
passer__jw76710 分钟前
【LeetCode】【算法】283. 移动零
数据结构·算法·leetcode
Ocean☾16 分钟前
前端基础-html-注册界面
前端·算法·html
顶呱呱程序24 分钟前
2-143 基于matlab-GUI的脉冲响应不变法实现音频滤波功能
算法·matlab·音视频·matlab-gui·音频滤波·脉冲响应不变法
爱吃生蚝的于勒1 小时前
深入学习指针(5)!!!!!!!!!!!!!!!
c语言·开发语言·数据结构·学习·计算机网络·算法
羊小猪~~1 小时前
数据结构C语言描述2(图文结合)--有头单链表,无头单链表(两种方法),链表反转、有序链表构建、排序等操作,考研可看
c语言·数据结构·c++·考研·算法·链表·visual studio
王哈哈^_^1 小时前
【数据集】【YOLO】【VOC】目标检测数据集,查找数据集,yolo目标检测算法详细实战训练步骤!
人工智能·深度学习·算法·yolo·目标检测·计算机视觉·pyqt
星沁城1 小时前
240. 搜索二维矩阵 II
java·线性代数·算法·leetcode·矩阵
脉牛杂德2 小时前
多项式加法——C语言
数据结构·c++·算法
legend_jz2 小时前
STL--哈希
c++·算法·哈希算法
kingmax542120082 小时前
初三数学,最优解问题
算法