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

简介:

@[TOC]

题目

力扣链接:

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;
}

总结

接触新的方法,思考吸收!!!!
相关文章
|
7月前
|
算法 程序员
【算法训练-链表 六】【链表查找】:链表中倒数第k个节点
【算法训练-链表 六】【链表查找】:链表中倒数第k个节点
55 0
【链表OJ 11】复制带随机指针的链表
【链表OJ 11】复制带随机指针的链表
|
索引
【Leetcode -138.复制带随机指针的链表 -2130.链表最大孪生和】
【Leetcode -138.复制带随机指针的链表 -2130.链表最大孪生和】
49 0
|
1月前
|
算法 索引
单链表题+数组题(快慢指针和左右指针)
单链表题+数组题(快慢指针和左右指针)
39 1
|
6月前
|
存储 算法
数据结构和算法学习记录——线性表之单链表(上)-初始单链表及其尾插函数(顺序表缺陷、单链表优点、链表打印)
数据结构和算法学习记录——线性表之单链表(上)-初始单链表及其尾插函数(顺序表缺陷、单链表优点、链表打印)
45 0
|
7月前
|
索引
【力扣刷题】删除链表的倒数第 N 个结点、两两交换链表中的节点、随机链表的复制
【力扣刷题】删除链表的倒数第 N 个结点、两两交换链表中的节点、随机链表的复制
37 0
|
7月前
20005.LeetCode 876. 给定一个带有头结点 head 的非空单链表,返回链表的中间结点。 如果有两个中间结点,则返回第二个中间结点。
20005.LeetCode 876. 给定一个带有头结点 head 的非空单链表,返回链表的中间结点。 如果有两个中间结点,则返回第二个中间结点。
40 0
|
算法 C语言 C++
【链表】Leetcode 138. 复制带随机指针的链表
这题虽然为中等难度,但找到方法后,考察的也仅是链表的增删查改四种操作。
64 0
|
算法 C语言
链表中的倒数第k个结点 合并两个链表 分割链表 链表的回文结构
链表中的倒数第k个结点 合并两个链表 分割链表 链表的回文结构
89 0