数据结构(7)单链表算法题OVA

随机链表的复制

1、题目描述

https://leetcode.cn/problems/copy-list-with-random-pointer

2、思路分析

第一步、在原链表的基础上拷贝节点

第二步、置random指针

只要节点不为空,那么就满足以下这个结论:copy -> random = cur -> random -> next

第三步、断开新旧链表

定义指针pcur指向原链表的头结点,用来遍历整个链表,再定义拷贝链表的头尾指针copyHead和copyTail。

3、参考代码

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

    return newNode;
}
void AddNode(Node* head)
{
    Node* pcur = head;
    while(pcur)
    {
        Node* newnode = buyNode(pcur->val);
        Node* next = pcur->next;
        newnode->next = next;
        pcur->next = newnode;
        pcur = next;
    }
}
void setRandom(Node* head)
{
    Node* pcur = head;
    while(pcur)
    {
        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);
    //断开新链表
    Node* pcur = head;
    Node* copyHead, *copyTail;
    copyHead = copyTail = pcur->next;
    while(copyTail->next)
    {
        pcur = copyTail->next;
        copyTail->next = pcur->next; 
        copyTail = copyTail->next;
    }
    return copyHead;
}
相关推荐
旖-旎11 分钟前
哈希表(存在重复元素||)(4)
数据结构·c++·算法·leetcode·哈希算法·散列表
被摘下的星星20 分钟前
数据结构中逻辑结构和存储结构对应有哪些
数据结构
磊 子33 分钟前
八大排序之冒泡排序+选择排序
数据结构·算法·排序算法
潇洒畅想39 分钟前
1.1 从∑到∫:用循环理解求和与累积
java·数据结构·python·算法
计算机安禾1 小时前
【数据结构与算法】第41篇:图论(五):拓扑排序与关键路径
c语言·数据结构·c++·算法·图论·visual studio
玉树临风ives3 小时前
atcoder ABC 453 题解
数据结构·c++·算法·图论·atcoder
琪伦的工具库3 小时前
批量PDF合并工具使用说明:批量合并与直接合并两种模式,拖拽排序/页面范围/遍历子目录/重名自动处理
数据结构·pdf·排序算法
山甫aa3 小时前
哈希集合-----从零开始的数据结构学习
数据结构·算法·哈希算法
say_fall3 小时前
有关算法的简单数学问题
数据结构·c++·算法·职场和发展·蓝桥杯
小杰帅气3 小时前
算法的时间和空间复杂度
数据结构