LeetCode Hot100 138.随机链表的复制

2023-12-15 19:29:29

题目

给你一个长度为?n?的链表,每个节点包含一个额外增加的随机指针?random?,该指针可以指向链表中的任何节点或空节点。

构造这个链表的?深拷贝。?深拷贝应该正好由?n?个?全新?节点组成,其中每个新节点的值都设为其对应的原节点的值。新节点的?next?指针和?random?指针也都应指向复制链表中的新节点,并使原链表和复制链表中的这些指针能够表示相同的链表状态。复制链表中的指针都不应指向原链表中的节点?

例如,如果原链表中有?X?和?Y?两个节点,其中?X.random --> Y?。那么在复制链表中对应的两个节点?x?和?y?,同样有?x.random --> y?。

返回复制链表的头节点。

用一个由?n?个节点组成的链表来表示输入/输出中的链表。每个节点用一个?[val, random_index]?表示:

  • val:一个表示?Node.val?的整数。
  • random_index:随机指针指向的节点索引(范围从?0?到?n-1);如果不指向任何节点,则为??null?。

你的代码??接受原链表的头节点?head?作为传入参数。

方法:哈希表 + 两次遍历

代码

class Solution {
    public Node copyRandomList(Node head) {
        if (head == null) {
            return null;
        }
        Node cur = head;
        HashMap<Node, Node> map = new HashMap<>();
        while (cur != null) {
            map.put(cur, new Node(cur.val));
            cur = cur.next;
        }
        cur = head;
        while (cur != null) {
            map.get(cur).next = map.get(cur.next);
            map.get(cur).random = map.get(cur.random);
            cur = cur.next;
        }
        return map.get(head);
    }
}

时间复杂度O( n )

空间复杂度O( n )

文章来源:https://blog.csdn.net/qq_57349657/article/details/135023564
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。