715. Range 模块

Range 模块是跟踪数字范围的模块。你的任务是以一种有效的方式设计和实现以下接口。

addRange(int left, int right) 添加半开区间 [left, right),跟踪该区间中的每个实数。添加与当前跟踪的数字部分重叠的区间时,应当添加在区间 [left, right) 中尚未跟踪的任何数字到该区间中。

queryRange(int left, int right) 只有在当前正在跟踪区间 [left, right) 中的每一个实数时,才返回 true。

removeRange(int left, int right) 停止跟踪区间 [left, right) 中当前正在跟踪的每个实数。

示例:

addRange(10, 20): null
removeRange(14, 16): null
queryRange(10, 14): true (区间 [10, 14) 中的每个数都正在被跟踪)
queryRange(13, 15): false (未跟踪区间 [13, 15) 中像 14, 14.03, 14.17 这样的数字)
queryRange(16, 17): true (尽管执行了删除操作,区间 [16, 17) 中的数字 16 仍然会被跟踪)

提示:

半开区间 [left, right) 表示所有满足 left <= x < right 的实数。
对 addRange, queryRange, removeRange 的所有调用中 0 < left < right < 10^9。
在单个测试用例中,对 addRange 的调用总数不超过 1000 次。
在单个测试用例中,对 queryRange 的调用总数不超过 5000 次。
在单个测试用例中,对 removeRange 的调用总数不超过 1000 次。
class RangeModule {

     TreeSet<Interval> ranges;
public RangeModule() {
ranges = new TreeSet();
} public void addRange(int left, int right) {
Iterator<Interval> itr = ranges.tailSet(new Interval(0, left - 1)).iterator();
while (itr.hasNext()) {
Interval iv = itr.next();
if (right < iv.left) break;
left = Math.min(left, iv.left);
right = Math.max(right, iv.right);
itr.remove();
}
ranges.add(new Interval(left, right));
} public boolean queryRange(int left, int right) {
Interval iv = ranges.higher(new Interval(0, left));
return (iv != null && iv.left <= left && right <= iv.right);
} public void removeRange(int left, int right) {
Iterator<Interval> itr = ranges.tailSet(new Interval(0, left)).iterator();
ArrayList<Interval> todo = new ArrayList();
while (itr.hasNext()) {
Interval iv = itr.next();
if (right < iv.left) break;
if (iv.left < left) todo.add(new Interval(iv.left, left));
if (right < iv.right) todo.add(new Interval(right, iv.right));
itr.remove();
}
for (Interval iv: todo) ranges.add(iv);
}
} class Interval implements Comparable<Interval>{
int left;
int right; public Interval(int left, int right){
this.left = left;
this.right = right;
} public int compareTo(Interval that){
if (this.right == that.right) return this.left - that.left;
return this.right - that.right;
} } /**
* Your RangeModule object will be instantiated and called as such:
* RangeModule obj = new RangeModule();
* obj.addRange(left,right);
* boolean param_2 = obj.queryRange(left,right);
* obj.removeRange(left,right);
*/

最新文章

  1. [Python] 学习资料汇总
  2. CI框架 数据库批量插入 insert_batch()
  3. Makefile---make内嵌函数及make命令显示 (九)
  4. vbs自学备份
  5. Fiddler 的几个用法
  6. openssl CA 自签证书,阿里云配置tomcat https
  7. Temporary Post Used For Theme Detection (19f70e1d-5d8d-4c19-aef1-5b5a71ae0c47 - 3bfe001a-32de-4114-a6b4-4005b770f6d7)
  8. jQuery.fn.serialize 阅读
  9. 【企业库6】【日志应用程序块】实验2:创建和使用异步Trace Listener
  10. HDU 4940(杭电更多的学校#7 1006) Destroy Transportation system(到处乱混)
  11. ASP.NET MVC+EF框架+EasyUI实现权限管理系列(6)- EF上下文实例管理
  12. iOS 开发者应该知道的 ARM 结构
  13. js备战春招の四の表单
  14. ActiveMQ(七)_伪集群和主从高可用使用(转)
  15. 如何在Cocos2D 1.0 中掩饰一个精灵(六)
  16. jQuery UI弹出新窗体
  17. Hibernate入门(三)
  18. python爬虫工程师各个阶段需要掌握的技能和知识介绍
  19. MySQL 系列(四) 主从复制、读写分离、模拟宕机、备份恢复方案生产环境实战
  20. python学习笔记12-深浅拷贝

热门文章

  1. Python 为什么抛弃累赘的花括号,使用缩进来划分代码块?
  2. qt绘制甘特图
  3. MYSQL 日月周季年分组
  4. 浅析Spring中AOP的实现原理——动态代理
  5. Mysql 常用函数(15)- upper 函数
  6. MYsql 8 连接报错 MySQLNonTransientConnectionException: Could not create connection to database server.
  7. chrome安装工具
  8. Analysis分析器
  9. 搞懂:前端跨域问题JS解决跨域问题VUE代理解决跨域问题原理
  10. ABAP基础1:概念