LeetCode352 将数据流变为多个不相交区间

1 题目

给你一个由非负整数 a1, a2, ..., an 组成的数据流输入,请你将到目前为止看到的数字总结为不相交的区间列表。

实现 SummaryRanges 类:

  • SummaryRanges() 使用一个空数据流初始化对象。
  • void addNum(int val) 向数据流中加入整数 val 。
  • int[][] getIntervals() 以不相交区间 [starti, endi] 的列表形式返回对数据流中整数的总结

2 思路

对于一组数据,

1 2 3 5 7 8

将连续的数字归纳到一个区间内,因此该数组的表示为[[1,3][5,5][7,8]]

方法1:列表+二分查找

使用一个数组存储维护所有的不相交区间,当有新元素添加时,通过二分查找的方式找到添加的位置,

  • 如果在区间内,例如[1,3]中添加2,此时2元素已经存在。则直接跳过,
  • 如果不在区间内,当添加的元素在区间的左右边界时,则需要考虑是否存在合并区间的情况。
    • 当元素正好是上一个区间的右边界+1,且是下一个区间的的左边界-1,此时需要合并区间,例如[0,0][2,3],添加1,此时合并区间为[0,3]
    • 当元素正好是上一个区间的右边界+1,或者是下一个区间的的左边界-1,更新区间的左右边界即可
    • 当元素不满足以上情况,则单独成为一个区间[1,1][5,5]添加3后为[1,1][3,3][5,5]

方法2:并查集

使用一个10000长度的数组parent模拟该区间,数组内存储该元素父元素的之,初始化时,每个元素单独成区间。

使用一个set集合存储出现过的元素

为集合建立并查集,集合的父亲代表连通集的右边界

每次获取区间进行一次并查集的查询操作,相邻的区间会被合并,遍历每个出现过的元素(从小到大排序),

  • 如果元素小于结果集的尾值,则意味着该元素已经包含在结果集中,直接跳过,
  • 如果小于尾值,则需要以该元素为左边界建立区间,然后根据parent数组查询右边界即可

3 Code

import bisect
class SummaryRanges:
def __init__(self):
#模拟区间
self.p=[i for i in range(100005)]
#存储出现过的元素
self.nums=[] def addNum(self, val: int) -> None:
if val not in self.nums:
#保证插入后数组是有序的
bisect.insort(self.nums,val)
#该元素的右边界是它下一个元素的右边界
self.p[val]=self.p[val+1] def parent(self,num):
#单独成区间,直接返回该元素
if num==self.p[num]:
return num
#递归查找父元素
self.p[num]=self.parent(self.p[num])
return self.p[num] def getIntervals(self) -> List[List[int]]:
res=[]
#遍历每个元素
for i in range(len(self.nums)):
#大于结果集尾值则跳过
if len(res)!=0 and res[-1][1]>=self.nums[i]:
continue
#将左右边界插入
res.append([self.nums[i],self.parent(self.nums[i])-1])
return res

LeetCode352 将数据流变为多个不相交区间的更多相关文章

  1. Java实现 LeetCode 352 将数据流变为多个不相交区间

    352. 将数据流变为多个不相交区间 给定一个非负整数的数据流输入 a1,a2,-,an,-,将到目前为止看到的数字总结为不相交的区间列表. 例如,假设数据流中的整数为 1,3,7,2,6,-,每次的 ...

  2. [Swift]LeetCode352. 将数据流变为多个不相交间隔 | Data Stream as Disjoint Intervals

    Given a data stream input of non-negative integers a1, a2, ..., an, ..., summarize the numbers seen ...

  3. HDU 2037 - 今年暑假不AC - [经典 选择不相交区间 问题]

    是一道很经典的选择不相交区间的问题. 关于选择不相交区间,可以参考刘汝佳.也可以参考:http://blog.csdn.net/dgq8211/article/details/7534488 以及模板 ...

  4. Codeforces Round #384 (Div. 2) A B C D dfs序+求两个不相交区间 最大权值和

    A. Vladik and flights time limit per test 2 seconds memory limit per test 256 megabytes input standa ...

  5. 区间不相交&区间覆盖

    //code by virtualtan 2018 寒7 区间不相交 #include <cstdio> #include <algorithm> #define MAXN 1 ...

  6. AcWing 908. 最大不相交区间数量

    //1.将每个区间按右端点从小到大排序 //2.从前往后依次枚举每个区间,如果当前区间中已经包含点,就直接跳过,否则,选择当前区间的右端点 //选右端点的话,可以尽可能的包含在多个区间里 //那么选的 ...

  7. 洛谷 P1803 凌乱的yyy【经典贪心/选择不相交区间】

    题目背景 快noip了,yyy很紧张! 题目描述 现在各大oj上有n个比赛,每个比赛的开始.结束的时间点是知道的. yyy认为,参加越多的比赛,noip就能考的越好(假的) 所以,他想知道他最多能参加 ...

  8. (选择不相交区间)今年暑假不AC hdu2037

    今年暑假不AC Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)Total Sub ...

  9. LeetCode刷题总结-二分查找和贪心法篇

    本文介绍LeetCode上有关二分查找和贪心法的算法题,推荐刷题总数为16道.具体考点归纳如下: 一.二分查找 1.数学问题 题号:29. 两数相除,难度中等 题号:668. 乘法表中第k小的数,难度 ...

随机推荐

  1. 刷题-力扣-337. 打家劫舍 III

    337. 打家劫舍 III 题目链接 来源:力扣(LeetCode) 链接:https://leetcode-cn.com/problems/house-robber-iii 著作权归领扣网络所有.商 ...

  2. centos 搭建jenkins+git+maven

      git+maven+jenkins持续集成搭建 发布人:[李源]  2017-12-08 04:33:37   一.搭建说明 系统:centos 6.5 jdk:1.8.0_144 jenkins ...

  3. springMVC学习总结(一) --springMVC搭建

    springMVC学习总结(一) --springMVC搭建 搭建项目 1.创建一个web项目,并在项目中的src文件夹下创建一个包com.myl.controller. 2.添加相应jar包 3.在 ...

  4. noip模拟44

    A. Emotional Flutter 直接将所有黑块平移到 \([1-k,0]\) 的区间即可,然后找有没有没被覆盖过的整点 注意特判 \(1-k\) 以及 \(0\) 的可行性,考场这里写挂成 ...

  5. Intel® QAT加速卡之Linux上编程说明

    QAT Software for Linux 1. Introduction 该程序员指南提供了有关软件体系结构和使用指南的信息. 相关的英特尔QAT软件库文档中记录了有关使用英特尔QuickAssi ...

  6. Sentry Web 前端监控 - 最佳实践(官方教程)

    系列 1 分钟快速使用 Docker 上手最新版 Sentry-CLI - 创建版本 快速使用 Docker 上手 Sentry-CLI - 30 秒上手 Source Maps Sentry For ...

  7. DHCP的原理和配置

    前言 在大型企业网络中,会有大量的主机或设备需要获取IP地址等网络参数.如果采用手工配置,工作量大且不好管理,如果有用户擅自修改网络参数,还有可能会造成 IP地址冲突等问题.使用动态主机配置协议DHC ...

  8. lua中的sleep实现

    这篇文章主要介绍了Lua中实现sleep函数功能的4种方法,本文讲解了在一个死循环中设置一个跳出条件方法.调用系统的sleep函数法.Windows下ping命令法.socket库中select函数法 ...

  9. vscode快速添加引号 批量增加引号(用于批量格式化代码)

    一.在浏览器中将Params复制到pycharm的py文件中 二.选中需要添加引号的部分,Ctrl+H 调出替换工具栏 三.填写正则表达式 (.*?): (.*) '$1':'$2', 右侧注意点击使 ...

  10. Linux从头学13:想彻底搞懂“系统调用”的底层原理?建议您别错过这篇【调用门】

    作 者:道哥,10+年嵌入式开发老兵,专注于:C/C++.嵌入式.Linux. 关注下方公众号,回复[书籍],获取 Linux.嵌入式领域经典书籍:回复[PDF],获取所有原创文章( PDF 格式). ...