当前位置: 首页 > news >正文

中国上海网深圳优化seo

中国上海网,深圳优化seo,哪个网站找做软件,怎么用htlm5自己做网站目录 题目描述:138. 复制带随机指针的链表(中等)题目接口解题思路代码 PS: 题目描述:138. 复制带随机指针的链表(中等) 给你一个长度为 n 的链表,每个节点包含一个额外增加的随机指针 random &…

目录

  • 题目描述:138. 复制带随机指针的链表(中等)
    • 题目接口
    • 解题思路
    • 代码
  • PS:

题目描述:138. 复制带随机指针的链表(中等)

给你一个长度为 n 的链表,每个节点包含一个额外增加的随机指针 random ,该指针可以指向链表中的任何节点或空节点。

构造这个链表的 深拷贝。 深拷贝应该正好由 n全新 节点组成,其中每个新节点的值都设为其对应的原节点的值。新节点的 next 指针和 random 指针也都应指向复制链表中的新节点,并使原链表和复制链表中的这些指针能够表示相同的链表状态。复制链表中的指针都不应指向原链表中的节点 。

例如,如果原链表中有 XY 两个节点,其中 X.random --> Y 。那么在复制链表中对应的两个节点 xy ,同样有 x.random --> y

返回复制链表的头节点。

用一个由 n 个节点组成的链表来表示输入/输出中的链表。每个节点用一个 [val, random_index] 表示:

  • val:一个表示 Node.val 的整数。
  • random_index:随机指针指向的节点索引(范围从 0n-1);如果不指向任何节点,则为 null
    你的代码 接受原链表的头节点 head 作为传入参数。

LeetCode做题链接:LeetCode-复制带随机指针的链表

示例 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]]

提示:

0 <= n <= 1000
-104 <= Node.val <= 104
Node.random 为 null 或指向链表中的节点。

题目接口

/*
// Definition for a Node.
class Node {int val;Node next;Node random;public Node(int val) {this.val = val;this.next = null;this.random = null;}
}
*/class Solution {public Node copyRandomList(Node head) {}
}

解题思路

参考题解:图解 138. 复制带随机指针的链表
主要思路:

  • 1.根据遍历到的原节点创建对应的新节点,每个新创建的节点是在原节点后面
  • 2.新节点的随机指针就是原节点的随机指针的next(重点)
  • 3.将两个链表分开,返回新链表

代码

/*
// Definition for a Node.
class Node {int val;Node next;Node random;public Node(int val) {this.val = val;this.next = null;this.random = null;}
}
*/class Solution {public Node copyRandomList(Node head) {if (head == null) {return null;}Node p = head;//第一步,在每个原节点后面创建一个新节点//1->1'->2->2'->3->3'while (p != null) {Node newNode = new Node(p.val);newNode.next = p.next;p.next = newNode;// p 指向原链表的的下一个结点,然后继续插入p = newNode.next;}p = head;//第二步,设置新节点的随机节点while (p != null) {if (p.random != null) {// 新节点的随机指针就是原节点的随机指针的nextp.next.random = p.random.next;}// 每次都跳两次p = p.next.next;}// 定义一个新的链表头结点,这个结点的next才是我们需要返回的新链表Node dummy = new Node(-1);p = head;Node cur = dummy;//第三步,将两个链表分离while (p != null) {cur.next = p.next;cur = cur.next;p.next = cur.next;p = p.next;}return dummy.next;}
}

成功!
在这里插入图片描述

PS:

感谢您的阅读!如果您觉得本篇文章对您有所帮助,请给予博主一个喔~

http://www.hengruixuexiao.com/news/45564.html

相关文章:

  • html静态网站下载百度如何推广广告
  • dw网站制作网站查询关键词排名软件
  • 免费b站推广网站app国外免费源码共享网站
  • 使用三剑客做网站渠道营销推广方案
  • 企业网站开源代码网站推广app软件
  • 网站制作培训学校最近一周的热点新闻
  • 南宁公司网站建设网站申请流程
  • 做百度移动网站排名软广东seo推广哪里好
  • 域名备案平台关键词排名优化系统
  • 岚山建设网站seo外贸推广
  • 盗取dede系统做的网站模板百度推广联盟
  • 邢台网站建设哪里有5118网站查询
  • 手表网站建设手机营销软件
  • 如何根据仿站做网站今日头条10大新闻
  • 湖南工程建设监理有限公司网站有哪些网站可以免费推广
  • 上海专业网站设计杭州优化公司多少钱
  • 怎样让网站优化的方式结构优化
  • 为什么做网站费用贵惠州seo推广优化
  • 洮南网站建设哪家好学历提升哪个教育机构好一些
  • 网站开发 慕课免费建站模板
  • 域名注册商哪个好seo推广效果
  • wordpress安装 万网seo咨询价格找推推蛙
  • 网站做的一样算不算侵权少儿培训
  • 怎样建设企业网站 用于宣传百度一下百度官方网
  • 网站风格什么意思黄山网络推广公司
  • 做商城网站的流程百度公司招聘官网最新招聘
  • 上海市住房和城乡建设部网站有没有永久免费crm
  • 如何做网站对话框百度推广客户端mac版
  • 网站如何做才容易被搜索到网络营销项目策划方案
  • 数字营销经典案例怎样优化网站排名靠前