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

    给定一个链表,每个节点包含一个额外增加的随机指针,该指针可以指向链表中的任何节点或空节点。
    要求返回这个链表的深拷贝。 
     
    示例:
     
    输入:
    {"$id":"1","next":{"$id":"2","next":null,"random":{"$ref":"2"},"val":2},"random":{"$ref":"2"},"val":1}
    解释:
    节点 1 的值是 1,它的下一个指针和随机指针都指向节点 2 。
    节点 2 的值是 2,它的下一个指针指向 null,随机指针指向它自己。
     
    提示:
    你必须返回给定头的拷贝作为对克隆列表的引用。
     
    来源:力扣(LeetCode)
    链接:https://leetcode-cn.com/problems/copy-list-with-random-pointer
    著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。
     
    原链表
     
     
    新链表
     
     
     
    根据random的地址获得节点位置
     
     
     
     
     
     
     
     
     
    有了节点位置,就可以设置 new_node->random
     
     
     
    random指向NULL,new_node->random->NULL
     
     1 class Node {
     2 public:
     3     int val;
     4     Node *next;
     5     Node *random;
     6     
     7     Node(int _val) : val(_val), next(NULL), random(NULL) {}
     8 };
     9 
    10 class Solution {
    11 public:
    12     Node* copyRandomList(Node* head) {
    13         map<Node *, int> node_map;//当前节点及其编号的映射
    14         vector<Node *> node_vec;
    15         Node *ptr = head;
    16         
    17         int i = 0;
    18         while (ptr) { //初始化
    19             node_vec.push_back(new Node(ptr->val));
    20             node_map[ptr] = i;
    21             ptr = ptr->next;
    22             ++i;
    23         }
    24         node_vec.push_back(0);
    25         
    26         ptr = head;
    27         i = 0;
    28         while (ptr) {
    29             node_vec[i]->next = node_vec[i+1];
    30             if (ptr->random) {
    31                 int id = node_map[ptr->random];
    32                 node_vec[i]->random = node_vec[id];
    33             } else {
    34                 node_vec[i]->random = NULL;
    35             }
    36             ptr = ptr->next;
    37             ++i;
    38         }
    39         return node_vec[0];
    40     }
    41 };
    测试

     1 int main(int argc, const char * argv[]) {
     2     Node a(1);
     3     Node b(2);
     4     Node c(3);
     5     Node d(4);
     6     Node e(5);
     7     a.next = &b;
     8     b.next = &c;
     9     c.next = &d;
    10     d.next = &e;
    11     a.random = &c;
    12     b.random = &d;
    13     c.random = &c;
    14     e.random = &d;
    15     
    16     Solution solve;
    17     Node *head = solve.copyRandomList(&a);
    18     while (head) {
    19         cout <<"head->val:" <<head->val <<' ';
    20         if (head->random) {
    21             cout <<"head->random->val:" <<head->random->val <<endl;
    22         } else {
    23             cout <<"head->random->NULL" <<endl;
    24         }
    25         head = head->next;
    26     }
    27 
    28     return 0;
    29 }
    View Code

  • 相关阅读:
    Java基础知识回顾之一 ----- 基本数据类型
    大数据初学者应该知道的知识
    MyEclipse 快捷键大全
    hibernate简单入门教程(一)---------基本配置
    MyEclipse中文注释乱码解决
    中间件(WAS、WMQ)运维 9个常见难点解析
    Oracle PL/SQL Dev工具(破解版)被植入勒索病毒的安全预警及自查通告
    呼叫中心系统的相关术语
    INFORMATICA 开发规范
    什么是RESTful API
  • 原文地址:https://www.cnblogs.com/i-8023-/p/11826150.html
Copyright © 2011-2022 走看看