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

建设网站企业专业服务玄幻小说排行榜百度风云榜

建设网站企业专业服务,玄幻小说排行榜百度风云榜,深圳品牌设计网站,android开发用什么软件文章目录 Remove Zero Sum Consecutive Nodes from Linked List 从链表中删去总和值为零的连续节点问题描述:分析代码 Remove Zero Sum Consecutive Nodes from Linked List 从链表中删去总和值为零的连续节点 问题描述: 给你一个链表的头节点 head&am…

文章目录

  • Remove Zero Sum Consecutive Nodes from Linked List 从链表中删去总和值为零的连续节点
    • 问题描述:
    • 分析
    • 代码

Remove Zero Sum Consecutive Nodes from Linked List 从链表中删去总和值为零的连续节点

问题描述:

给你一个链表的头节点 head,请你编写代码,反复删去链表中由 总和 值为 0 的连续节点组成的序列,直到不存在这样的序列为止。

删除完毕后,请你返回最终结果链表的头节点。

节点数量 范围[1,1000],节点值范围[-1000,1000]

分析

这个问题要求把链表中和为0的连续节点删除,很明显是一个前缀和处理,而且数据规模不大,暴力处理也可以。
首先使用一个dummy,方便处理,使用map记录每个节点的前缀和,map[前缀和,节点].
在遍历链表的过程中,首先计算该节点的前缀和sum,如果sum之前出现过,说明遇到了一段需要删除的区间,删除处理。此时map需要清空,然后从头,再进行遍历循环,直到遍历到结尾。
整体的思路就是暴力模拟,时间复杂度还是比较高的,这里是尝试记录待删除区域的开始节点,然后遍历找到区间的结尾,进行处理,缺点就是一旦进行删除,map中记录的开始节点,可能就失效,要么使用额外的时间删除,要么从新计算。

另一种思路也是记录,但是这里是记录前缀和最后出现的节点。这样第一次遍历时完成map记录。
第二次遍历,一旦发现出现了前缀和,就可以找到这个区域,进行删除。因为删除的区间和是0,所以不影响前缀和记录,同样也不会影响map中记录的前缀和节点。

代码

public ListNode removeZeroSumSublists(ListNode head) {Map<Integer,ListNode> map = new HashMap();ListNode vh = new ListNode(0);vh.next = head;ListNode p = vh,pre =null;int sum = 0; while(p!=null){sum += p.val;if(map.containsKey(sum)){pre = map.get(sum);pre.next = p.next;map.clear();p = vh;sum =0;}else{map.put(sum,p);p = p.next;}}return vh.next; }

时间复杂度 O(N?)

空间复杂度: O(N)

public ListNode removeZeroSumSublists(ListNode head) {Map<Integer,ListNode> map = new HashMap();ListNode vh = new ListNode(0);vh.next = head;ListNode p = head;int sum = 0;while(p!=null){sum += p.val;map.put(sum,p);p=p.next;}p = vh;sum = 0;while(p!=null){sum += p.val;if(map.containsKey(sum)){ListNode q = map.get(sum);p.next = q.next; }p = p.next;} return vh.next; }

时间复杂度 O(N)

空间复杂度: O(N)

Tag

Hash linkedlist

http://www.rdtb.cn/news/22937.html

相关文章:

  • html如何做自己的网站网站推广方式组合
  • excel服务器做网站seo推广优化工具
  • 威县做网站哪家好中国域名注册局官网
  • 定制高端网站建设企业全国各城市疫情搜索高峰进度
  • 工厂视频网站建设临沂seo推广
  • 上海最繁华的五个区上海企业优化
  • 白石洲附近做网站公司营销平台建设
  • 专业网站定制报价seo排名教程
  • 制作个人网站怎么制作媒体平台
  • 网站建设搜狐明星百度指数排名
  • 12345浏览器网址大全吉安seo招聘
  • 有名的网站建设公司百度网盘怎么找资源
  • 贵阳做网站活动推广宣传方案
  • 河南优化网站百度网盘app下载安装 官方下载
  • 黑龙江网站备案免费企业网站模板源码
  • 本地高端网站建设信息大全精准引流推广
  • 企业微信网站建设搜索大全搜索引擎
  • 智能网站建设维护软件app推广项目
  • 怎么制作网站游戏宁波seo公司哪家好
  • 哪个网站做设计兼职不用压金网络服务主要包括什么
  • 毕设做系统与网站答辩nba最新赛程
  • 建立网站得多少钱浏览器网页版入口
  • 网站建设需要多少钱费用百度普通收录
  • 梅州做网站公司seo81
  • 网站建设行业北京网络推广优化公司
  • 10个神奇的.htaccess技巧(for wordpress)超级优化空间
  • 国外知名网站发外链平台
  • wordpress 界面设计河南seo外包
  • 帮助网站源码seo常用方法
  • 大团网站建设谷歌ads