138. Copy List with Random Pointer
A linked list is given such that each node contains an additional random pointer which could point to any node in the list or null.
Return a deep copy of the list.
/**
* Definition for singly-linked list with a random pointer.
* struct RandomListNode {
* int label;
* RandomListNode *next, *random;
* RandomListNode(int x) : label(x), next(NULL), random(NULL) {}
* };
*/
class Solution {
public:
RandomListNode *copyRandomList(RandomListNode *head) { }
};
============
这个链表节点和普通链表的区别就是,有一个random指针,可以指向链表中的任何元素或者为nullptr
返回产生一个深copy.
思路:
第一遍,对list的每一个节点复制一次放在节点后面,这一次只复制节点的next指针,不复制节点的random指针
第一遍结束后我们的链表节点
a->b->c->d... 会变成a->fake_a->b->fake_b->c->fake_c->d->d->fake_d....
第二遍再对链表进行random指针复制
第三遍堆链表进行拆分,这样的我们可以将链表分离出来一个新的链表.
code如下:
/**
* Definition for singly-linked list with a random pointer.
* struct RandomListNode {
* int label;
* RandomListNode *next, *random;
* RandomListNode(int x) : label(x), next(NULL), random(NULL) {}
* };
*/
class Solution {
public:
RandomListNode *copyRandomList(RandomListNode *head){
RandomListNode *curr = head;
while(curr){
RandomListNode *node = new RandomListNode(curr->label);
node->next = curr->next;
curr->next = node;
curr = node->next;
}///a->f_a-> b->f_b-> ...
curr = head;
while(curr){
if(curr->random){
curr->next->random = curr->random->next;
}
curr = curr->next->next;
} ///partition it into two linktable
RandomListNode dummy(-);
RandomListNode *h = &dummy;
curr = head;
while(curr){
h->next = curr->next;
curr->next = curr->next->next;
h = h->next;
curr = curr->next;
}
h->next = nullptr;
return dummy.next;
}
};
138. Copy List with Random Pointer的更多相关文章
- 133. Clone Graph 138. Copy List with Random Pointer  拷贝图和链表
		133. Clone Graph Clone an undirected graph. Each node in the graph contains a label and a list of it ... 
- [LeetCode] 138. Copy List with Random Pointer 拷贝带有随机指针的链表
		A linked list is given such that each node contains an additional random pointer which could point t ... 
- leetcode 138. Copy List with Random Pointer ----- java
		A linked list is given such that each node contains an additional random pointer which could point t ... 
- 【LeetCode】138. Copy List with Random Pointer
		题目: A linked list is given such that each node contains an additional random pointer which could poi ... 
- 138. Copy List with Random Pointer (Graph, Map; DFS)
		A linked list is given such that each node contains an additional random pointer which could point t ... 
- Java for LeetCode 138 Copy List with Random Pointer
		A linked list is given such that each node contains an additional random pointer which could point t ... 
- 138. Copy List with Random Pointer (not do it by myself)
		A linked list is given such that each node contains an additional random pointer which could point t ... 
- [LeetCode] 138. Copy List with Random Pointer 拷贝带随机指针的链表
		A linked list is given such that each node contains an additional random pointer which could point t ... 
- 138 Copy List with Random Pointer 复制带随机指针的链表
		给出一个链表,每个节点包含一个额外增加的随机指针,该指针可以指向链表中的任何节点或空节点.返回一个深拷贝的链表. 详见:https://leetcode.com/problems/copy-list- ... 
随机推荐
- vim 被墙
			我只能说,呵呵.还好这货可以进. http://vim.wendal.net/ 
- NOIP2016 D2T1 組合數問題(problem)
			题目描述 组合数C(n,m)表示的是从n个物品中选出m个物品的方案数.举个例子,从(1,2,3) 三个物品中选择两个物品可以有(1,2),(1,3),(2,3)这三种选择方法.根据组合数的定 义,我们 ... 
- hdu3416 最短路+最大流
			题意:有 n 点 m 边,有出发点 A 到达点 B ,只允许走原图中的最短路,但每条边只允许被走一次,问最多能找出多少条边不重复的最短路 一开始做到的时候瞎做了一发最短路,WA了之后也知道显然不对,就 ... 
- android开源项目---blog篇
			本文转载于:http://blog.csdn.net/likebamboo/article/details/19081241 主要介绍那些乐于分享并且有一些很不错的开源项目的个人和组织.Follow大 ... 
- Python 基础语法(四)
			Python 基础语法(四) --------------------------------------------接 Python 基础语法(三)------------------------- ... 
- VC++多线程编程
			一.问题的提出 编写一个耗时的单线程程序: 新建一个基于对话框的应用程序SingleThread,在主对话框IDD_SINGLETHREAD_DIALOG添加一个按钮,ID为IDC_SLEEP_SIX ... 
- QQ登入(5)获取空间相册,新建相册,上传图片到空间相册
			///////////////////////////////////////////////////////////////////// 获取相册列表:必须先授权登入 1.1. String mA ... 
- CodeFirstMigrations更新数据库结构(EF数据迁移)
			背景 code first起初当修改model后,要持久化至数据库中时,总要把原数据库给删除掉再创建(DropCreateDatabaseIfModelChanges),此时就会产生一个问题,当我们的 ... 
- 在svg里面画虚线
			使用stroke-dasharray="3 2" 属性,其中3和2分别表示画的长度和间隙的长度 比如 <line x1="0" y1="5&q ... 
- ASP.NET Cookie 概述【转】
			来源:http://msdn.microsoft.com/zh-cn/library/ms178194(VS.80).aspx ASP.NET Cookie 概述 Cookie 提供了一种在 Web ... 
