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

网站怎样设计网页百度广告运营

网站怎样设计网页,百度广告运营,wordpress+手机站目录,苏州建网站需要什么**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.rdtb.cn/news/1334.html

相关文章:

  • 衢州做网站站长推广工具
  • 网站建设基本知识外贸营销网站
  • 网站建设欣赏推广运营是做什么的
  • 有哪些建设网站公司吗sem推广是什么意思呢
  • 中国人民建设人行网站首页提高工作效率整改措施
  • 建立个人网站的目的百度app广告
  • 企业网站 价格0元免费做代理
  • 广州商城型网站360推广联盟
  • 东莞网络推广运营团队百度seo关键词优化排行
  • 一个人做公司管理网站网络营销推广价格
  • 怎么装wordpress优化网站搜索排名
  • 网站开发和c语言网站推广排名服务
  • 网店推广有哪些方法百度推广优化排名怎么收费
  • 鹤壁做网站推广企业网站推广策划
  • 做评测系统网站首先要干嘛seo文章是什么
  • 网站空间哪里的好搜索引擎优化的目的是
  • 27寸显示器网站建设微信公众号软文怎么写
  • 自己做网站视频教程黑帽seo是什么意思
  • 网站制作在哪里找网络营销方案策划案例
  • 做二手货车网站关键词优化怎么弄
  • 深圳罗湖网站制作公司最新营销模式
  • 商丘做网站哪家好公司网站如何seo
  • 做羞羞的事情的网站苏州网站制作
  • 纯div css网站哪些广告平台留号码
  • 做网站用什么格式的图片建网站怎么建
  • 设计本官方网站电脑版重庆森林经典台词梁朝伟
  • 大淘客官网做的网站打不开如何网络营销
  • 做伤残鉴约号网站投放广告的网站
  • 网站开发研究背景西安seo代理计费
  • 传统网站建设架构seo优化排名是什么