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

徐州做网站建设公司百度怎么把自己网站展现在百度

徐州做网站建设公司,百度怎么把自己网站展现在百度,深圳电器公司招聘,公司门户网站模板**138.**给你一个长度为 n 的链表,每个节点包含一个额外增加的随机指针 random ,该指针可以指向链表中的任何节点或空节点。 构造这个链表的 深拷贝。 深拷贝应该正好由 n 个 全新 节点组成,其中每个新节点的值都设为其对应的原节点的值。新节…

**138.**给你一个长度为 n 的链表,每个节点包含一个额外增加的随机指针 random ,该指针可以指向链表中的任何节点或空节点。
构造这个链表的 深拷贝。 深拷贝应该正好由 n 个 全新 节点组成,其中每个新节点的值都设为其对应的原节点的值。新节点的 next 指针和 random 指针也都应指向复制链表中的新节点,并使原链表和复制链表中的这些指针能够表示相同的链表状态。复制链表中的指针都不应指向原链表中的节点 。
例如,如果原链表中有 X 和 Y 两个节点,其中 X.random --> Y 。那么在复制链表中对应的两个节点 x 和 y ,同样有 x.random --> y 。
返回复制链表的头节点。
用一个由 n 个节点组成的链表来表示输入/输出中的链表。每个节点用一个 [val, random_index] 表示:
val:一个表示 Node.val 的整数。
random_index:随机指针指向的节点索引(范围从 0 到 n-1);如果不指向任何节点,则为 null 。
你的代码 只 接受原链表的头节点 head 作为传入参数。
示例 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]]

  •   /*// 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;}}*/
    
  • 我的原始人解法:先遍历一遍链表,复制出没有 random 的链表,与此同时记录下每个原结点对应的复制节点。第二轮遍历的时候复制 random 即可:
  •   public Node copyRandomList(Node head) {Map<Node,Node> map = new HashMap<>();// 头部加了一个哑结点Node node = new Node(-1);Node temp = node;Node tempHead = head;while(head!=null){node.next = new Node(head.val);map.put(head,node.next);head=head.next;node=node.next;}head = tempHead;node = temp;while(head!=null){Node random = map.get(head.random);node.next.random = random;head=head.next;node=node.next;}return temp.next;}
    
  • 或者可以像他人题解先只是创建每个节点,第二轮遍历的时候直接在 map 中把节点连起来创建链表
  •   public Node copyRandomList(Node head) {if(head == null) return null;Node cur = head;Map<Node, Node> map = new HashMap<>();// 3. 复制各节点,并建立 “原节点 -> 新节点” 的 Map 映射while(cur != null) {map.put(cur, new Node(cur.val));cur = cur.next;}cur = head;// 4. 构建新链表的 next 和 random 指向while(cur != null) {map.get(cur).next = map.get(cur.next);map.get(cur).random = map.get(cur.random);cur = cur.next;}// 5. 返回新链表的头节点return map.get(head);}
    
  • 还有个巧妙的思路,构建一个新的拼接链表为:原节点1 -> 新节点1 -> 原节点2 -> 新节点1 ->…。然后你只需要遍历这个链表,新结点的 next 就为该节点的 next 的 next,新结点的 random 就为原结点的 random 的 next。其实这也是一种原节点对应新节点的形式,只不过在 map 中表现为 key->val,在这里表现为 node -> node.next。
  •   public Node copyRandomList(Node head) {if(head == null){return null;}// 暂存头结点,待会用来重新遍历Node tempHead = head;// 拼接新链表while(head != null){Node node = new Node(head.val);node.next = head.next;head.next = node;head = node.next;}// 头结点复原,再遍历一遍构建新链表 random 的指向head = tempHead;while(head != null){if(head.random != null){head.next.random = head.random.next;}head = head.next.next;}// 头结点再复原,最后遍历一遍拆分出原链表和结果链表head = tempHead;// 最后结果的头结点,下面用来遍历Node ans = head.next;// 暂存最后结果的头结点Node tempAns = ans;// 构建到尾结点就不构建了,所以是 ans.next != null,也没 next 让你继续构建了while(ans.next != null){// 或者 head.next = head.next.nexthead.next = ans.next;head = head.next;ans.next = head.next;ans = ans.next;}// 原链表尾结点复原head.next = null;return tempAns;}
    
http://www.yayakq.cn/news/825013/

相关文章:

  • 徐州本地网站编程入门先学什么软件
  • 公司网站开发费用计入什么类型的网站容易做
  • 我想在阿里巴巴网站开店 怎么做九江集团网站建设公司
  • 淘宝店铺网站建立长春网站设计制作培训
  • 手机网站域做什么广告wordpress页面文章列表
  • 怎样做企业网站备案深圳网站定制 开发
  • 如何建设一个静态网站泰安二手房最新发布出售房源
  • 网站建设调查回访表国外做评论的网站
  • 怎么建设58同城网站网站专业建设
  • 做民宿要给网站多少钱深圳网站建设那家好
  • 织梦后台怎么做网站地图.net 微信网站开发
  • 重庆建设工程安全管理协会网站推广链接跳转
  • 无锡高端网站建设开发怎么做动态的实时更新的网站
  • 那网站做问答wordpress登陆网址
  • 徐州在线制作网站ps在线图片编辑
  • 上海做家教网站有哪些wordpress 淘客主题
  • 郑州粒米seo外包seo优化查询
  • 怎么下载网站的模板受雇去建设网站类网站
  • 网站设计的软件广西建设厅网官网
  • 做网站的岗位好吗天元建设集团有限公司 李增启
  • 网站开发费用预算网络整合营销理论概念
  • 公司简历模板电子版seo推广关键词公司
  • 房地产网站加盟北京建站开发
  • 襄阳网站制作公司有哪些找工程做在哪个网站?
  • 网站建设 软件有哪些方面房产中介哪家口碑比较好
  • 怎样制作网站汕头seo外包平台
  • 网站建设公司有哪些网站数据分析建设
  • 网站建设添加资料辽宁建设工程信息网a类业绩定义
  • 公司网站客户案例南宁网站建设业务员
  • 电子商务网站规划与建设温州seo教程