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

湖南营销型网站建设 要上磐石网络手机网站js电话悬浮

湖南营销型网站建设 要上磐石网络,手机网站js电话悬浮,营销有哪些基本内容,做网站代码目录 题目描述: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.yayakq.cn/news/362728/

相关文章:

  • 网站可以做哪些广告大型网站设计网站
  • 网站设计有哪些语言版本教做奥数的网站
  • 杭州九鸿科技网站开发可以做h5的网站
  • 四川建设厅网上查询网站首页php查询信息 wordpress插件
  • 什么语言做网站快flash网站怎么做音乐停止
  • 做游戏网站需要哪些许可自动引流推广app
  • 银川网站建设怎么样网站模板怎么连接域名
  • 境外网站搭建wordpress中药材主题
  • 汽车类网站设计规划网页视频下载慢怎么办
  • dede 网站地图模板地旺建设官方网站
  • 网站建设中期目标关键词排名优化佛山售后
  • 在网站上使用特殊字体wordpress备份文章
  • 电子商务网站建设培训小结自适应网站源码
  • 网站上的地图导航怎么做的wordpress 浏览器不居中
  • 石岩网站建设qq云端服务器
  • 最简单的网站代码宁波网站建设招聘网
  • 网页设计网站建设流程青柠影院免费观看电视剧高清
  • 室内设计招标网站《水利建设与管理》杂志社网站
  • 做360网站优化排男的做直播网站
  • 做网站选什么系统tp5第二季企业网站开发auth权限认证
  • 旅游网站建设水平评价提供建站服务的网络公司的比较
  • 海南网络公司网站建设上海最新通报: 上海最新通报
  • 厦门外贸网站深圳坪山医院
  • windowxp做网站服务器渭南几个区
  • 如何给网站做推广网站里的注册怎么做
  • 绍兴网站建设服务物联网应用技术是干什么的
  • 怎样做静态网站珠海模板建站平台
  • 网站程序问题网站软文设计
  • 大型网站如何开发湛江市出行防疫政策
  • 做系统哪个网站好电子商务网站的建设的意义