复杂带有随机指针的单链表

题目

力扣链接:

image-20211112160326801

思路

image-20211112163211784

代码

/**
 * Definition for a Node.
 * struct Node {
 *     int val;
 *     struct Node *next;
 *     struct Node *random;
 * };
 */
struct Node* newnode()
{
struct Node*node=(struct Node*)malloc(sizeof(struct Node));
if(node==NULL)
{
return NULL;
}
return node;
}

struct Node* copyRandomList(struct Node* head) {
   //在复制链表时,copy结点很容易。
   //但是对random指针,需要知道原链表random的指向结点在链表中的 相对位置,以便copy结点中random的指向新的结点。
   //如果遍历原链表,去找相对位置,时间复杂度0(N^2)
   //相复杂的原因是:我们把2个链表分开看了。
   //如果我们把copy的结点插入原链表就可以极大解决相对位置问题。
   //针对相对位置,插入到原链表中,更好
    if(head==NULL)
    {
        return NULL;
    }
struct Node*cur=head;	
while(cur!=NULL)//插入到原链表
{
struct Node*tmp=cur->next;
struct Node*node=newnode();
node->val=cur->val;
cur->next=node;
node->next=tmp;
cur=tmp;
}
cur=head;
while(cur!=NULL)//修改copy的random
{
struct Node*tmp=cur->next;
if(cur->random==NULL)
{
    tmp->random=NULL;
}else
{

    tmp->random=cur->random->next;
}
cur=tmp->next;
}
struct Node*copyhead=head->next;
struct Node*copynode=copyhead;
while(copynode->next!=NULL)//提取copy的结点
{
    struct Node*tmp=copynode->next->next;
    copynode->next=tmp;
    copynode=tmp;
}
return copyhead;
}

总结

接触新的方法,思考吸收!!!

  • 3
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值