热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

[Leetcode]138.复制带随机指针的链表

目录1.题目链接2.1解法①(暴力)2.1.1解法思路:2.1.2代码实现:2.2解法②(进阶)2.1.1解法思路:2.2.

目录

1.题目链接

2.1解法①(暴力)

2.1.1解法思路:

2.1.2代码实现:

2.2解法②(进阶)

2.1.1解法思路:

2.2.2代码实现:




1.题目链接


138. 复制带随机指针的链表 - 力扣(LeetCode)



2.1解法①(暴力)


2.1.1解法思路:


时间复杂度:O(N^2) 空间复杂度O(N); 

①先遍历原链表,复制出一个一模一样的单链表,先不管random的问题;

②然后再遍历新生成的链表,同时进行random指针的拷贝:

这个实现是对于新生成的每一个节点,然后找到原链表的对应的节点,然后遍历原链表找出原链表对应的random指针指向的节点,计算random指向的节点和原链表中对应的节点的相对位置i;

然后在新生成的单链表中找到相同相对位置的节点,然后再将新生成的单链表中的该节点的random指向这个相对位置对应的节点。



2.1.2代码实现:

struct Node* BuyNode(int x)
{struct Node* New = (struct Node*)malloc(sizeof(struct Node));New->val = x;New->next = NULL;New->random = NULL;return New;
}int CheckList(struct Node* head, struct Node*cur)
{int x = 0;while(cur->random != head){head = head->next;x++;}return x;
}
struct Node* copyRandomList(struct Node* head)
{struct Node* cur = head;struct Node* temp = BuyNode(-1);struct Node* pre = temp;//先复制单链表while(cur){temp->next = BuyNode(cur->val);temp = temp->next;cur = cur->next;}//复制随机指针//1遍历原链表,遇到随即指针不为空的节点;//2然后再遍历链表找到随即指针指向的节点,计算位置;//3然后放入新的链表中temp = pre->next;//初始化新链表箭头cur = head;//初始化旧链表指针while(cur){if(cur->random != NULL){int x = CheckList(head, cur);struct Node* shead = pre->next;for(int i = 0; i next;}temp->random = shead;}cur = cur->next;temp = temp->next;}return pre->next;
}



2.2解法②(进阶)


2.1.1解法思路:


①先进行如下的操作:

在每个节点后面插入一个新的节点然后每个节点的val和前一个节点相同;

 ②然后要做的就是处理新插入节点的random指针,进行第一步的操作就是为了方便第二步来处理random指针的:具体实现的方法就是给定一个指针cur来遍历原来就有的节点,然后遇到random指针不为空的节点,然后就将其next的random指向其的random的next即可;

(这个是最关键的)实现如下的效果;

 ③第三步也是最后一步,然后将那些在原链表上插入的新节点按顺序,尾插成一个新的链表;



2.2.2代码实现:

struct Node* BuyNode(int x)
{struct Node* New = (struct Node*)malloc(sizeof(struct Node));New->val = x;New->next = NULL;New->random = NULL;return New;
}struct Node* copyRandomList(struct Node* head)
{struct Node* cur = head; //先复制单链表while(cur){struct Node* cnext = cur->next;struct Node* New = BuyNode(cur->val);cur->next = New;New->next = cnext;cur = cur->next->next;}//给定randomcur = head;while(cur){if(cur->random){cur->next->random = cur->random->next;}cur = cur->next->next;}//生成新链表cur = head;struct Node* Bhead = (struct Node*)malloc(sizeof(struct Node));Bhead->next = NULL;struct Node* tail = Bhead;int x = 1;while(cur){if(x % 2 == 0){tail->next = cur;tail = tail->next;}x++;cur = cur->next;}return Bhead->next;
}


以上就是本博客的所有内容了!


推荐阅读
  • PHP图片截取方法及应用实例
    本文介绍了使用PHP动态切割JPEG图片的方法,并提供了应用实例,包括截取视频图、提取文章内容中的图片地址、裁切图片等问题。详细介绍了相关的PHP函数和参数的使用,以及图片切割的具体步骤。同时,还提供了一些注意事项和优化建议。通过本文的学习,读者可以掌握PHP图片截取的技巧,实现自己的需求。 ... [详细]
  • Java容器中的compareto方法排序原理解析
    本文从源码解析Java容器中的compareto方法的排序原理,讲解了在使用数组存储数据时的限制以及存储效率的问题。同时提到了Redis的五大数据结构和list、set等知识点,回忆了作者大学时代的Java学习经历。文章以作者做的思维导图作为目录,展示了整个讲解过程。 ... [详细]
  • eclipse学习(第三章:ssh中的Hibernate)——11.Hibernate的缓存(2级缓存,get和load)
    本文介绍了eclipse学习中的第三章内容,主要讲解了ssh中的Hibernate的缓存,包括2级缓存和get方法、load方法的区别。文章还涉及了项目实践和相关知识点的讲解。 ... [详细]
  • 本文详细介绍了Linux中进程控制块PCBtask_struct结构体的结构和作用,包括进程状态、进程号、待处理信号、进程地址空间、调度标志、锁深度、基本时间片、调度策略以及内存管理信息等方面的内容。阅读本文可以更加深入地了解Linux进程管理的原理和机制。 ... [详细]
  • 本文介绍了为什么要使用多进程处理TCP服务端,多进程的好处包括可靠性高和处理大量数据时速度快。然而,多进程不能共享进程空间,因此有一些变量不能共享。文章还提供了使用多进程实现TCP服务端的代码,并对代码进行了详细注释。 ... [详细]
  • 本文讨论了clone的fork与pthread_create创建线程的不同之处。进程是一个指令执行流及其执行环境,其执行环境是一个系统资源的集合。在调用系统调用fork创建一个进程时,子进程只是完全复制父进程的资源,这样得到的子进程独立于父进程,具有良好的并发性。但是二者之间的通讯需要通过专门的通讯机制,另外通过fork创建子进程系统开销很大。因此,在某些情况下,使用clone或pthread_create创建线程可能更加高效。 ... [详细]
  • Day2列表、字典、集合操作详解
    本文详细介绍了列表、字典、集合的操作方法,包括定义列表、访问列表元素、字符串操作、字典操作、集合操作、文件操作、字符编码与转码等内容。内容详实,适合初学者参考。 ... [详细]
  • 本文介绍了在CentOS上安装Python2.7.2的详细步骤,包括下载、解压、编译和安装等操作。同时提供了一些注意事项,以及测试安装是否成功的方法。 ... [详细]
  • JDK源码学习之HashTable(附带面试题)的学习笔记
    本文介绍了JDK源码学习之HashTable(附带面试题)的学习笔记,包括HashTable的定义、数据类型、与HashMap的关系和区别。文章提供了干货,并附带了其他相关主题的学习笔记。 ... [详细]
  • 海马s5近光灯能否直接更换为H7?
    本文主要介绍了海马s5车型的近光灯是否可以直接更换为H7灯泡,并提供了完整的教程下载地址。此外,还详细讲解了DSP功能函数中的数据拷贝、数据填充和浮点数转换为定点数的相关内容。 ... [详细]
  • Givenasinglylinkedlist,returnarandomnode'svaluefromthelinkedlist.Eachnodemusthavethe s ... [详细]
  • 本文介绍了使用Python解析C语言结构体的方法,包括定义基本类型和结构体类型的字典,并提供了一个示例代码,展示了如何解析C语言结构体。 ... [详细]
  • STL迭代器的种类及其功能介绍
    本文介绍了标准模板库(STL)定义的五种迭代器的种类和功能。通过图表展示了这几种迭代器之间的关系,并详细描述了各个迭代器的功能和使用方法。其中,输入迭代器用于从容器中读取元素,输出迭代器用于向容器中写入元素,正向迭代器是输入迭代器和输出迭代器的组合。本文的目的是帮助读者更好地理解STL迭代器的使用方法和特点。 ... [详细]
  • 深入解析Linux下的I/O多路转接epoll技术
    本文深入解析了Linux下的I/O多路转接epoll技术,介绍了select和poll函数的问题,以及epoll函数的设计和优点。同时讲解了epoll函数的使用方法,包括epoll_create和epoll_ctl两个系统调用。 ... [详细]
  • Java编程实现邻接矩阵表示稠密图的方法及实现类介绍
    本文介绍了Java编程如何实现邻接矩阵表示稠密图的方法,通过一个名为AMWGraph.java的类来构造邻接矩阵表示的图,并提供了插入结点、插入边、获取邻接结点等功能。通过使用二维数组来表示结点之间的关系,并通过元素的值来表示权值的大小,实现了稠密图的表示和操作。对于对稠密图的表示和操作感兴趣的读者可以参考本文。 ... [详细]
author-avatar
港1009
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有