题解 | #复杂链表的复制#

复杂链表的复制

https://www.nowcoder.com/practice/f836b2c43afc4b35ad6adc41ec941dba

首先我们在 每个节点的后面 复制一个节点,复制的就是当前节点的下一个节点,这样除 头结点外,每个节点都有了一个复制,然后就是修改 random指针,只要让每一个节点的 random 指针的指向,都指向现在节点 的下一个就可以了!就是p->next->random=p->random->next
下一步再分离出这个链表就可以了
image-20220714172457389

/*
struct RandomListNode {
    int label;
    struct RandomListNode *next, *random;
    RandomListNode(int x) :
            label(x), next(NULL), random(NULL) {
    }
};
*/
class Solution {
public:
    RandomListNode* Clone(RandomListNode* pHead) {
        //复制新节点
        RandomListNode* cur=pHead;
        while(cur!=nullptr)
        {
            RandomListNode* ncur=new RandomListNode(cur->label);
            RandomListNode* next=cur->next;

            cur->next=ncur;
            ncur->next=next;
            cur=next;
        }

        //复制random指针
        cur=pHead;
        while(cur!=nullptr)
        {
            if(cur->random!=nullptr)
            {
                cur->next->random=cur->random->next;
            }

            cur=cur->next->next;
        }

        //分离得到复制的链表
        RandomListNode* dummy=new RandomListNode(-1);
        RandomListNode* newCur=dummy;
        cur=pHead;
        while(cur!=nullptr)
        {
            newCur->next=cur->next;
            newCur=newCur->next;

            //恢复原来的链表
            cur->next=cur->next->next;
            //更新到下一个结点
            cur=cur->next;
        }

        return dummy->next;
    }
};
#剑指offer#
全部评论

相关推荐

点赞 评论 收藏
分享
2024-12-27 23:45
已编辑
三江学院 Java
程序员牛肉:死局。学历+无实习+项目比较简单一点。基本就代表失业了。 尤其是项目,功能点实在是太假了。而且提问点也很少。第一个项目中的使用jwt和threadlocal也可以作为亮点写出来嘛?第二个项目中的“后端使用restful风格”,“前端采用vue.JS”,“使用redis”也可以作为亮点嘛? 项目实在是太简单了,基本就是1+1=2的水平。而你目标投递的肯定也是小厂,可小厂哪里有什么培养制度,由于成本的问题,人家更希望你来能直接干活,所以你投小厂也很难投。基本就是死局,也不一定非要走后端这条路。可以再学一学后端之后走测试或者前端。 除此之外,不要相信任何付费改简历的。你这份简历没有改的必要了,先沉淀沉淀
点赞 评论 收藏
分享
评论
1
收藏
分享

创作者周榜

更多
牛客网
牛客企业服务