随机链表的复制数据结构oj题(力口138)

目录

问题描述

问题解读分析

解决代码


问题描述

问题解读分析

这里我们要注意深拷贝和随机指针 ,首先就是深拷贝对应的浅拷贝是和原链表用一个结点,而深拷贝则对应的不和原链表一个结点,也就是说需要我们自己开辟空间去创建一个结点和原链表一模一样。而这里随机指针,是链表中一个指针,他随机但是又固定,固定是因为我们不需要随机给他寻找结点,而是实例给,但是随机又不能琢磨他只能在相对结点的右边,而还有相对于这个结点的左边。所以这里最为复杂的是该如何处理random指针,这里很难寻找到相对结点靠左的结点和random对应,我们这里选择在原链表基础上进行拷贝,通过原链表上的random指针的next(这个表示在原链表上的下一个指针,这个指针就是复制的链表)与我们拷贝对应 。很抽象上图:

最后一步就是将原链表和复制好的链表断开

解决代码

cpp 复制代码
/**
 * Definition for a Node.
 * struct Node {
 *     int val;
 *     struct Node *next;
 *     struct Node *random;
 * };
 */
struct Node* buyNode(int x)
{
    struct Node* newnode = (struct Node*)malloc(sizeof(struct Node));
    if(newnode == NULL)
    {
        perror("malloc");
        return NULL;
    }
    newnode->val = x;
    newnode->random= newnode->next = NULL;
    return newnode;
}

void AddNode(struct Node* phead)
{
    struct Node* pcur = phead;
    while(pcur)
    {
        struct Node* next = pcur->next;
        struct Node* newnode =buyNode(pcur->val);
        pcur->next = newnode;
        newnode->next = next;
        pcur = next;
    }
}
void setRandom(struct Node* phead)
{
    struct Node* pcur = phead;
    //根据newnode->random = pcur->random->next
    while(pcur)
    {
        struct Node* copy = pcur->next;
        if(pcur->random)//防止为空时解引用
        {
            copy->random = pcur->random->next;
        }
        pcur = copy->next;
    }
}
struct Node* copyRandomList(struct Node* head) {
	if(head == NULL)//防止没意义空指针的发生
    {
        return head;
    }
    //复制原链表
    AddNode(head);
    //复制random
    setRandom(head);
    //将原链表上的复制链表拆除
    struct Node* pcur = head;
    struct Node* copyHead=pcur->next;
    struct Node* copyTail = pcur->next;
    head->next = copyTail->next;//原链表链接
    while(pcur->next)
    {
        //copyTail --- pcur->next
        pcur = copyTail->next;
        copyTail->next = pcur->next;
        copyTail = copyTail->next;
        //pcur ----- pcur->next
        pcur->next = copyTail->next;
    } 
    return copyHead;
}
相关推荐
梁辰兴1 小时前
数据结构:排序
数据结构·算法·排序算法·c·插入排序·排序·交换排序
野犬寒鸦1 小时前
力扣hot100:搜索二维矩阵 II(常见误区与高效解法详解)(240)
java·数据结构·算法·leetcode·面试
菜鸟得菜2 小时前
leecode kadane算法 解决数组中子数组的最大和,以及环形数组连续子数组的最大和问题
数据结构·算法·leetcode
楼田莉子2 小时前
C++算法专题学习——分治
数据结构·c++·学习·算法·leetcode·排序算法
ulias2123 小时前
各种背包问题简述
数据结构·c++·算法·动态规划
JuneXcy4 小时前
结构体简介
c语言·数据结构·算法
j_xxx404_6 小时前
数据结构:栈和队列力扣算法题
c语言·数据结构·算法·leetcode·链表
南莺莺6 小时前
假设一个算术表达式中包含圆括号、方括号和花括号3种类型的括号,编写一个算法来判别,表达式中的括号是否配对,以字符“\0“作为算术表达式的结束符
c语言·数据结构·算法·
野犬寒鸦7 小时前
力扣hot100:旋转图像(48)(详细图解以及核心思路剖析)
java·数据结构·后端·算法·leetcode
一枝小雨7 小时前
【OJ】C++ vector类OJ题
数据结构·c++·算法·leetcode·oj题