zoukankan      html  css  js  c++  java
  • leetcode138. 复制带随机指针的链表

    思路一:哈希

    借助哈希保存节点信息。

    代码

    时间复杂度:O(n)
    空间复杂度:O(n)

    class Solution{
    public:
        Node* copyRandomList(Node* head)
        {
            if(!head) return NULL;
            map<Node*,Node*>Map;
            //遍历链表,将原结点作为key,拷贝结点作为value保存在map
            Node* curr=head;
            while(curr)
            {
                Node* new_node=new Node(curr->val);
                Map[curr]=new_node;
                curr=curr->next;
            }
            //复制链表next和random指针
            curr=head;
            while(curr)
            {
                Map[curr]->next=Map[curr->next];
                Map[curr]->random=Map[curr->random];
                curr=curr->next;
            }
            return Map[head];
        }
    
    };

    2.原地复制

    1. 复制节点,同时将复制节点链接到原节点后面,如A->B->C 变为 A->A'->B->B'->C->C'。
    2. 设置节点random值。
    3. 将复制链表从原链表分离。
    class Solution {
    public:
        Node* copyRandomList(Node* head) {
            if (head == nullptr) {
                return head;
            }
            Node *node = head;
            //1. 将复制节点添加到原节点后面
            while (node != nullptr) {
                Node *copy = new Node(node->val, nullptr, nullptr);
                copy->next = node->next;
                node->next = copy;
                node = copy->next;
            }
            
            //2. 复制random节点
            node = head;
            while (node != nullptr) {
                if (node->random != nullptr) {
                    node->next->random = node->random->next;
                }            
                node = node->next->next;
            }
            
            //3. 分离链表
            node = head;
            Node *newHead = head->next;
            Node *newNode = newHead;
            while (node != nullptr) {
                node->next = node->next->next;     
                if (newNode->next != nullptr) {
                    newNode->next = newNode->next->next;            
                }            
                node = node->next;
                newNode = newNode->next;
            }
            return newHead;
        }
    };
  • 相关阅读:
    Windows安装深度学习框架Tensorflow GPU版本
    Genymotion3.0.4(with VirtualBox 个人免费版)安装及使用
    09.Python基础--迭代器
    08.Python基础--面向对象深入
    07.Python基础--面向对象
    06.Python基础--函数深入
    05.Python基础--函数
    04.Python基础--深入流程控制
    03.Python基础--流程控制
    02.Python基础--数据类型
  • 原文地址:https://www.cnblogs.com/renzmin/p/11885301.html
Copyright © 2011-2022 走看看