IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 数据结构与算法 -> 剑指 Offer 35. 复杂链表的复制 -> 正文阅读

[数据结构与算法]剑指 Offer 35. 复杂链表的复制

剑指 Offer 35. 复杂链表的复制

请实现 copyRandomList 函数,复制一个复杂链表。在复杂链表中,每个节点除了有一个 next 指针指向下一个节点,还有一个 random 指针指向链表中的任意节点或者 null。

?

示例 1:

输入:head = [[7,null],[13,0],[11,4],[10,2],[1,0]]
输出:[[7,null],[13,0],[11,4],[10,2],[1,0]]

?

示例 2:

输入:head = [[1,1],[2,1]]
输出:[[1,1],[2,1]]

?

示例 3:

?输入:head = [[3,null],[3,0],[3,null]]
输出:[[3,null],[3,0],[3,null]]

?

示例 4:
输入:head = []
输出:[]
解释:给定的链表为空(空指针),因此返回 null。
?

提示:

-10000 <= Node.val <= 10000
Node.random?为空(null)或指向链表中的节点。
节点数目不超过 1000 。
?

注意:本题与主站 138 题相同:https://leetcode-cn.com/problems/copy-list-with-random-pointer/

思路:见代码?

时间复杂度:O(n),两轮遍历链表,时间复杂度与常系数无关,即:O(n) + O(n) = O(n)?

空件复杂度:哈希表 map?使用线性大小的额外空间

/**
 * Definition for a Node.
 * type Node struct {
 *     Val int
 *     Next *Node
 *     Random *Node
 * }
 */

func copyRandomList(head *Node) *Node {
	// 方法1:
	// nodeMap := make(map[*Node]*Node)
	// for cur := head; cur != nil; cur = cur.Next {
	// 	nodeMap[cur] = &Node{ /*cur.Val, nil, nil*/ } // 首先构建每个单节点,赋值其Val,并初始化map
	// }
	
	// // 之所以用两个循环,就是为了好懂,其实理论上1个循环也是可以的
	// for cur := head; cur != nil; cur = cur.Next {
	// 	nodeMap[cur].Val, nodeMap[cur].Next, nodeMap[cur].Random = cur.Val, nodeMap[cur.Next], nodeMap[cur.Random] // ok 连接各个单节点的Next和Random
	// }
	// return nodeMap[head]

	// 方法2:
	nodeMap := make(map[*Node]*Node)
	for cur := head; cur != nil; cur = cur.Next {
		nodeMap[cur] = &Node{cur.Val, nil, nil} // 首先构建每个单节点,赋值其Val,并初始化map
	}

	// 之所以用两个循环,就是为了好懂,其实理论上1个循环也是可以的
	for cur := head; cur != nil; cur = cur.Next {
		// nodeMap[cur] = &Node{Val: cur.Val, Next: cur.Next, Random: cur.Random} // 错误,要取map中的Next
		// nodeMap[cur] = &Node{Next: nodeMap[cur.Next], Random: nodeMap[cur.Random]} // 错误 ??? 为什么这样写不行
		nodeMap[cur].Next, nodeMap[cur].Random = nodeMap[cur.Next], nodeMap[cur.Random] // ok 连接各个单节点的Next和Random
	}
	return nodeMap[head]
}

  数据结构与算法 最新文章
【力扣106】 从中序与后续遍历序列构造二叉
leetcode 322 零钱兑换
哈希的应用:海量数据处理
动态规划|最短Hamilton路径
华为机试_HJ41 称砝码【中等】【menset】【
【C与数据结构】——寒假提高每日练习Day1
基础算法——堆排序
2023王道数据结构线性表--单链表课后习题部
LeetCode 之 反转链表的一部分
【题解】lintcode必刷50题<有效的括号序列
上一篇文章      下一篇文章      查看所有文章
加:2021-08-19 12:18:53  更:2021-08-19 12:20:08 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年6日历 -2024/6/2 18:39:41-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码