鱼C论坛

 找回密码
 立即注册
查看: 1152|回复: 0

[技术交流] C++刷剑指offer(面试题35. 复杂链表的复制)【链表】

[复制链接]
发表于 2020-4-6 20:50:20 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
本帖最后由 糖逗 于 2020-5-8 17:45 编辑

题目描述:
  1. 请实现 copyRandomList 函数,复制一个复杂链表。在复杂链表中,每个节点除了有一个 next 指针指向下一个节点,还有一个 random 指针指向链表中的任意节点或者 null。

  2.  

  3. 示例 1:



  4. 输入:head = [[7,null],[13,0],[11,4],[10,2],[1,0]]
  5. 输出:[[7,null],[13,0],[11,4],[10,2],[1,0]]
  6. 示例 2:



  7. 输入:head = [[1,1],[2,1]]
  8. 输出:[[1,1],[2,1]]
  9. 示例 3:



  10. 输入:head = [[3,null],[3,0],[3,null]]
  11. 输出:[[3,null],[3,0],[3,null]]
  12. 示例 4:

  13. 输入:head = []
  14. 输出:[]
  15. 解释:给定的链表为空(空指针),因此返回 null。
  16.  

  17. 提示:

  18. -10000 <= Node.val <= 10000
  19. Node.random&#160;为空(null)或指向链表中的节点。
  20. 节点数目不超过 1000 。
  21. &#160;

  22. 来源:力扣(LeetCode)
  23. 链接:https://leetcode-cn.com/problems/fu-za-lian-biao-de-fu-zhi-lcof
  24. 著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。
复制代码



  1. /*
  2. // Definition for a Node.
  3. class Node {
  4. public:
  5.     int val;
  6.     Node* next;
  7.     Node* random;
  8.    
  9.     Node(int _val) {
  10.         val = _val;
  11.         next = NULL;
  12.         random = NULL;
  13.     }
  14. };
  15. */
  16. class Solution {
  17. public:
  18.     Node* copyRandomList(Node* head) {
  19.         if(head == NULL) return head;
  20.         Node* temp1 = head;
  21.         while(temp1){
  22.             Node* new_node = new Node(temp1 -> val);
  23.             Node* store = temp1 -> next;
  24.             temp1 -> next = new_node;
  25.             new_node -> next = store;
  26.             temp1 = store;
  27.         }
  28.         temp1 = head;
  29.         while(temp1){
  30.             Node* temp2 = temp1 -> next;
  31.             if(temp1 -> random){
  32.                 temp2-> random = temp1 ->random -> next;
  33.             }
  34.             else{
  35.                 temp2 -> random = NULL;
  36.             }
  37.             temp1 = temp2 -> next;
  38.         }

  39.         Node* old = head;
  40.         Node* res = head -> next;
  41.         Node* new_head = head -> next;
  42.         while(new_head->next && new_head){
  43.             Node* old1 = new_head -> next;
  44.             Node* new1 = old1 -> next;
  45.             old -> next = old1;
  46.             new_head -> next = new1;
  47.             old = old1;
  48.             new_head = new1;
  49.         }
  50.         if(old)
  51.             old->next=nullptr;
  52.         return res;

  53.         
  54.     }
  55. };
复制代码



注意事项:
1.大致思路如图1
2.if(old)
   old->next=nullptr;
这行代码保证以前的链的最后一个元素指向null指针


图1

图1

本帖被以下淘专辑推荐:

小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-7-2 15:43

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表