当前位置: 首页 > 编程日记 > 正文

合并区间(LintCode)

合并区间

给出若干闭合区间,合并所有重叠的部分。

样例

给出的区间列表 => 合并后的区间列表:

[                     [[1, 3],               [1, 6],[2, 6],      =>       [8, 10],[8, 10],              [15, 18][15, 18]            ]
]
挑战

O(n log n) 的时间和 O(1) 的额外空间。

思路是清晰的,代码是混乱的。先用Collection.sort()方法对List排序。当然也可以先toArray()然后用Arrays.sort()排序。但是都需要写一个实现Comparator接口的内部类。

 1 /**
 2  * Definition of Interval:
 3  * public class Interval {
 4  *     int start, end;
 5  *     Interval(int start, int end) {
 6  *         this.start = start;
 7  *         this.end = end;
 8  *     }
 9  */
10 
11 class Solution {
12     /**
13      * @param intervals: Sorted interval list.
14      * @return: A new sorted interval list.
15      */
16      
17     public class IntervalCmp implements Comparator<Interval> {
18         public int compare(Interval i1, Interval i2) {
19             if (i1.start < i2.start) return -1;
20             if (i1.start == i2.start && i1.end <= i2.end) return -1;
21             return 1;
22         }
23      }
24     public List<Interval> merge(List<Interval> intervals) {
25         if(intervals.size() == 1)return intervals;
26         List<Interval> list = new ArrayList<Interval>();
27         int max1 = -1;
28         int min1 = 99999999;
29         int max = -1;
30         int min = 99999999;
31         
32         //借助Collections。sort()排序,百度了一下JDK7不加上这句的话可能会报错
33         System.setProperty("java.util.Arrays.useLegacyMergeSort", "true");
34         Collections.sort(intervals, new IntervalCmp());
35         
36         for(int i = 0;i<intervals.size();i++) {
37             Interval x = intervals.get(i);
38             if(x.start > max1 || x.end < min1) {
39                 min = x.start;
40                 max = x.end;
41                 for(int j = i+1;j<intervals.size();j++) {
42                     Interval y = intervals.get(j);
43                     if(y.end >= min && y.start <= max) {
44                         if(max < y.end) {
45                             max = y.end;
46                         }
47                         if(min > y.start) {
48                             min = y.start;
49                         }
50                     }
51                 }
52                 x.end = max;
53                 x.start = min;
54                 if(max1 < max) max1 = max;
55                 if(min1 > min) min1 = min;
56                 list.add(x);
57             }
58         }
59         return list;
60     }
61 
62 }
View Code

在说一下比较器抛

java.lang.IllegalArgumentException: Comparison method violates its general contract

这个异常,JDK7以后用比较器在两个元素相等的情况下需要返回0。可参考:这里

转载于:https://www.cnblogs.com/FJH1994/p/5022466.html

相关文章:

Kylin集群部署和cube使用

Kylin集群部署和cube使用 安装集群环境节点 Kylin节点模式 Ip 内存 磁盘Node1 All 192.167.71.11 2G 80GNode2 query 192.168.71.12 1.5G 80GNode3 query 192.168.71.13 1.5G 80GKylin工作原理如下&#xff1a; 集群时间同步Ntp服务自行设置安装kylin之前所需要的环境Hadoop-2.…

就是个控制结构,Scala 能有什么新花样呢?

作者 | luanhz来源 | 小数志导读编程语言中最为基础的一个概念是控制结构&#xff0c;几乎任何代码都无时无刻不涉及到&#xff0c;其实也就无外乎3种&#xff1a;顺序、分支和循环。本文就来介绍Scala中控制结构&#xff0c;主要是分支和循环。Scala中的控制结构实质上与其他编…

快速开发一个PHP扩展

快速开发一个PHP扩展 作者&#xff1a;heiyeluren时间&#xff1a;2008-12-5博客&#xff1a;http://blog.csdn.net/heiyeshuwu 本文通过非常快速的方式讲解了如何制作一个PHP 5.2 环境的扩展&#xff08;PHP Extension&#xff09;&#xff0c;希望能够在图文的方式下让想快速…

oracle11g的安装

目录层次&#xff1a;linux->oracle软件->dbca数据库安装过程&#xff1a;虚拟机->linux->VMtools->拷贝数据库软件->创建一个目录mkdir->创建组.用户->修改根目录->设置参数->解压 >安装->oracle完成参考&#xff1a;安装oracle软件linu…

python 100例(10)

2019独角兽企业重金招聘Python工程师标准>>> 题目&#xff1a;古典问题&#xff1a;有一对兔子&#xff0c;从出生后第3个月起每个月都生一对兔子&#xff0c;小兔子长到第三个月后每个月又生一对兔子&#xff0c;假如兔子都不死&#xff0c;问每个月的兔子总数为多…

cocos2dx-3.9 集成admob

Part 1: 安装GoogleMobileAds framework &#xff08;即admob&#xff09; 1. 安装Cocoapods&#xff0c;否则解决依赖关系和配置真的会把人不累死也得烦死 sudo gem install cocoapods 国内用户安装过程中可能遇到SSL连接出错的问题&#xff0c;请参考 Cocoapod安装过程中的幺…

用C语言扩展PHP功能

用C语言扩展PHP功能建议读者群&#xff1a;熟悉c,linux,php PHP经过最近几年的发展已经非常的流行&#xff0c;而且PHP也提供了各种各样非常丰富的函数。但有时候我们还是需要来扩展PHP。比如&#xff1a;我们自己开发了一个数据库系统&#xff0c;而且有自己的库函数来操作数…

手把手快速实现 Resnet 残差模型实战

作者 | 李秋键 出品 | AI科技大本营&#xff08;ID:rgznai100&#xff09; 引言&#xff1a;随着深度学习的发展&#xff0c;网络模型的深度也随之越来越深&#xff0c;但随着网络模型深度的加深&#xff0c;往往会曾在这随着模型深度的加大&#xff0c;模型准确率反而下降的问…

JHipster开发环境安装

这里采用官方推荐的Yarn安装方法&#xff0c;默认操作系统为CentOS 7.4。 1 安装JDK 推荐版本&#xff1a;OpenJDK 1.8.0-64bit。 完整安装说明&#xff0c;请参考这里 2 安装Nodejs 推荐版本&#xff1a; v8.11.3 完整安装说明&#xff0c;请参考这里 3 安装Yarn 推荐版本&…

用C语言写PHP扩展

用C语言写PHP扩展 1&#xff1a;预定义 在home目录&#xff0c;也可以其他任意目录&#xff0c;写一个文件&#xff0c;例如caleng_module.def 内容是你希望定义的函数名以及参数&#xff1a; int a(int x,int y)string b(string str,int n) 2&#xff1a;到php源码目录的ext目…

Pandas 数据挖掘与分析时的常用方法

今天我们来讲一下用Pandas模块对数据集进行分析的时候&#xff0c;一些经常会用到的配置&#xff0c;通过这些配置的帮助&#xff0c;我们可以更加有效地来分析和挖掘出有价值的数据。数据集的准备这次我们需要用到的数据集是广为人所知的泰坦尼克号的乘客数据&#xff0c;我们…

MySQL基本概念

1. 分清几个概念&#xff1a;数据库&#xff0c;数据库对象和数据&#xff1b; 数据库分为&#xff1a;系统数据库和用户数据库&#xff1b; 系统数据库 是安装完MySQL服务器后自带的数据库&#xff0c;会记录一些必要的信息&#xff0c;用户不能直接修改这些系统数据库。转载…

SpringMvc+ajax实现文件跨域上传

最近开始学习SpringMVC框架&#xff0c;在学习数据绑定的时候&#xff0c;发现可以使用RequestParam注解绑定请求数据&#xff0c;实现了文件上传。但是如果一个项目是前后端分离的&#xff0c;前端系统向后端服务上传文件该怎么解决了&#xff1f; 首先考虑前端用哪一种方式进…

使用Nmap获取目标服务器开放的服务以及操作系统信息

http://nmap.org/download.html 1.下载安装rpm -vhU http://nmap.org/dist/nmap-5.61TEST5-1.i386.rpmrpm -vhU http://nmap.org/dist/zenmap-5.61TEST5-1.noarch.rpmrpm -vhU http://nmap.org/dist/ncat-5.61TEST5-1.i386.rpmrpm -vhU http://nmap.org/dist/nping-0.5.61TEST5…

Pandas 数据类型概述与转换实战

作者 | 周萝卜 来源 | 萝卜大杂烩 在进行数据分析时&#xff0c;确保使用正确的数据类型是很重要的&#xff0c;否则我们可能会得到意想不到的结果或甚至是错误结果。对于 pandas 来说&#xff0c;它会在许多情况下自动推断出数据类型 尽管 pandas 已经自我推断的很好了&#x…

7.10 数据注解特性--NotMapped

NotMapped特性可以应用到领域类的属性中&#xff0c;Code-First默认的约定&#xff0c;是为所有带有get,和set属性选择器的属性创建数据列。。 NotManpped特性打破了这个约定&#xff0c;你可以使用NotMapped特性到某个属性上面&#xff0c;然后Code-First就不会为这个属性就不…

Condition

2019独角兽企业重金招聘Python工程师标准>>> 1、Condition的简介 线程通信中的互斥除了用synchronized、Object类的wait()和notify()/notifyAll()方式实现外&#xff0c;方法JDK1.5中提供的Condition配套Lock可以实现相同的功能。Condition中的await()和signal()/si…

使用who.is查域名DNS信息以及用sameip.org查其他网站

www.who.is网站可以查域名信息&#xff0c;非常好用&#xff1a;例如查 hack-test.com然后我们可以找找同个IP上的其他站点&#xff08;旁站&#xff1a;sameip.org&#xff09;参考&#xff1a; 黑客是怎么攻击一个网站的&#xff1f;

基于 OpenCV 的人脸追踪

作者 | 努比 来源 | 小白学视觉 在Raspberry上启动项目很简单&#xff0c;所以让我们开始吧。 01. 产品清单 Raspberry Pi 4 Model B — 4GB 适用于Raspberry Pi的Pan-Tilt HAT Pi Camera v2 8MP 微型SD卡 迷你HDMI电缆 Raspberry Pi摄像头电缆—尺寸&#xff1a;457mm x …

-bash: /bin/rm: Argument list too long的解决办法

-bash: /bin/rm: Argument list too long的解决办法 当目录下文件太多时&#xff0c;用rm删除文件会报错&#xff1a; -bash: /bin/rm: Argument list too long 提示文件数目太多。 解决的办法是使用如下命令&#xff1a; ls | xargs -n 10 rm -fr ls 输出所有的文件名(用…

React使用ES6语法重构组件代码

首次使用react&#xff0c;要注意react不同版本库&#xff0c;是ES5还是ES6的写法&#xff0c;如何做到统一。下面对于ES6语法重构组件的代码如下&#xff1a;&#xff08;1&#xff09;原始代码&#xff1a; <script type"text/babel">var destinationdocumen…

PHP哈希表碰撞攻击原理

哈希表碰撞攻击&#xff08;Hashtable collisions as DOS attack&#xff09;的话题不断被提起&#xff0c;各种语言纷纷中招。本文结合PHP内核源码&#xff0c;聊一聊这种攻击的原理及实现。 哈希表碰撞攻击的基本原理 哈希表是一种查找效率极高的数据结构&#xff0c;很多语言…

Java8(jdk1.8)中文档注释处理工具javadoc的环境参量配置及使用方法

Java8(jdk1.8)中文档注释处理工具javadoc的环境参量配置及使用方法Java语言提供了一种功能强大的注释形式&#xff1a;文档注释。如果编写Java源代码时添加了合适的文档注释&#xff0c;然后通过JDK提供的javadoc工具可以直接将源代码里的文档注释提取成一份系统的API文档。jav…

如何读取Excel表格中不同sheet表的同一位置单元格数据,并绘制条形图呢?

作者 | 黄伟呢来源 | 数据分析与统计学之美今天&#xff0c;有位朋友在群里面咨询了一个问题&#xff1a;如何读取Excel表格中"不同sheet表"的同一位置单元格数据&#xff0c;并绘制条形图呢&#xff1f;有人提议用vba&#xff0c;但是不得不说&#xff0c;没有学过v…

vue-router学习笔记

配置路由模式 const routernew VueRouter({routes }) hash模式(默认):通过url的hash来模拟一个完整的url&#xff0c;于是当url改变时&#xff0c;页面不会重新加载。history模式&#xff1a;通过history完成url跳转而不需要重新加载页面。注意&#xff1a;为了防止404错误&…

PHP防止注入攻击

注入攻击不多说了PHP addslashes() 函数--单撇号加斜线转义PHP String 函数定义和用法addslashes() 函数在指定的预定义字符前添加反斜杠。这些预定义字符是&#xff1a;单引号 ()双引号 (")反斜杠 (\)NULL语法addslashes(string)参数描述string必需。规定要检查的字符串。…

首届腾讯数字安全创新大赛在京启动,挖掘新锐力量推动产业创新

3月10日&#xff0c;首届腾讯数字安全创新大赛在京正式启动。本次大赛由腾讯安全和中国产业互联网发展联盟联合主办&#xff0c;腾讯安全、KEEN、元起资本、赛博英杰、数世咨询等多家企业联合发起&#xff0c;中国产业互联网发展联盟安全专委会承办。 大赛旨在寻找网络安全新力…

oracle数据库无监听程序

在电脑---服务---启动oracle tns 如果还是出现错误的话&#xff0c;找到Net Manager&#xff0c;将网络的ip监听删除&#xff0c;将本机的主机名配好&#xff0c;即可打开tns服务 转载于:https://www.cnblogs.com/jiangsheng3/p/5025201.html

个人开发者即时到账收款方案 BufPay.com

BufPay 个人即时到账支付平台前言 作为独立开发者&#xff0c;一般只有一个人独立奋战&#xff0c;做出了产品需要收款是非常麻烦的&#xff0c;接入支付宝微信支付都需要公司公户&#xff0c;而注册公司、开公户等一系列操作非常麻烦&#xff0c;成本也很高一年也要 1w 左右。…

用 Python 制作数据大屏,超简单

作者 | 俊欣来源 | 关于数据分析与可视化今天我们用Streamlit模块来制作一个数据面板&#xff0c;将数据更加直观地呈现给别人观看&#xff0c;整个页面大致如下图所示&#xff1a;制作工具栏在页面的左侧是一个工具栏&#xff0c;工具栏中有多个按钮&#xff0c;分别是“About…