评论

收藏

[C++] #yyds干货盘点#算法大神对小码农说复制随机链表可以单独拿出来讲讲

编程语言 编程语言 发布于:2021-12-12 14:46 | 阅读数:299 | 评论:0

复制带随机指针的链表
==天下傻逼独一个就是我,我忘记了选c语言,用c++结果错误看一脸懵逼==
DSC0000.png


题目
DSC0001.png

==这题链表的复制难的地方就是随机指针random 如何复制他的指向,很多人的确想到了malloc节点,我也想到了malloc一个一个的节点,但是基本所有人都卡死在这里了,就是我们如何链,在这里我们就会又遇到先天性大佬的天赋思维力的压制,上一题是空间联想的压制。(来吧我小码农就喜欢给先天以及后天的大佬锤炼)==
思想
==普通拷贝==
DSC0002.png

==实际上想到这样也已经了不起了,有点磨具雏形了==
==顺藤摸瓜==(这个是真的奇兵记,暗度陈仓的感觉)
DSC0003.png

==脱裤子还需提裤子人==(上面暗度陈仓,这个就是单刀直入)
DSC0004.png

代码实现
DSC0005.gif

DSC0006.gif

==cur为NULL的时候就是停止copy的时候==
struct Node* cur = head;
  if(!cur)
    return NULL;
  while(cur)
  {
    //每次我们都要malloc一个copy节点
    struct Node* copy = (struct Node*)malloc(sizeof(struct Node));
    //开始给数据
    copy->val = cur->val;
    //开始插入
    copy->next = cur->next;
    cur->next = copy;
    //开始cur移动
    cur = copy->next;
  }
DSC0007.gif

==有人说为什么不在上面malloc节点的时候就链,因为那时候小孩还没出生你就让你的还在上学吗,没错为了卷你们,我准备偷偷生个小孩==
//节点copy好后开始random相链
  cur = head;
  while(cur)
  {
    //重新把之前开辟的节点给copy维护
    struct Node* copy = cur->next;
    if(cur->random == NULL)
      copy->random = NULL;
    else
      copy->random = cur->random->next;//上面的GIF的核心代码     
    cur = copy->next;  
  }
DSC0008.gif

然后拿下来一个个尾插,就是单刀直入==你要还原原来的链表顺序==
//开始一个一个尾插起来
  struct Node* copyHead = NULL;
  struct Node* copyTail = NULL;
  cur = head;
  while(cur)
  {
    //重新把之前开辟的节点给copy维护
    struct Node* copy = cur->next;
    //这边你需要一个next来还原原来链表顺序,你不能用完人家对人家不负责任
    struct Node* next = copy->next;
    if(copyHead == NULL)
    {
      copyHead = copy;
      copyTail = copy;
    }
    else
    {
      copyTail->next = copy;
      copyTail = copy;
    }    
    cur->next = next;//这一步看你对原来链表负不负责任
    cur = next;
  }
  return copyHead;
DSC0009.png
Node* copyRandomList(struct Node* head) {
  struct Node* cur = head;
  if(!cur)
    return NULL;
  while(cur)
  {
    //每次我们都要malloc一个copy节点
    struct Node* copy = (struct Node*)malloc(sizeof(struct Node));
    //开始给数据
    copy->val = cur->val;
    //开始插入
    copy->next = cur->next;
    cur->next = copy;
    //开始cur移动
    cur = copy->next;
  }
  //节点copy好后开始random相链
  cur = head;
  while(cur)
  {
    //重新把之前开辟的节点给copy维护
    struct Node* copy = cur->next;
    if(cur->random == NULL)
      copy->random = NULL;
    else
      copy->random = cur->random->next;//上面的GIF的核心代码     
    cur = copy->next;  
  }
  //开始一个一个尾插起来
  struct Node* copyHead = NULL;
  struct Node* copyTail = NULL;
  cur = head;
  while(cur)
  {
    //重新把之前开辟的节点给copy维护
    struct Node* copy = cur->next;
    //这边你需要一个next来还原原来链表顺序,你不能用完人家对人家不负责任
    struct Node* next = copy->next;
    if(copyHead == NULL)
    {
      copyHead = copy;
      copyTail = copy;
    }
    else
    {
      copyTail->next = copy;
      copyTail = copy;
    }    
    cur->next = next;//这一步看你对原来链表负不负责任
    cur = next;
  }
  return copyHead;
}
</div>
    
    <div id="asideoffset"></div>

关注下面的标签,发现更多相似文章