merge intervals

Given a collection of intervals, merge all overlapping intervals.

For example,
Given [1,3],[2,6],[8,10],[15,18],
return [1,6],[8,10],[15,18].

又是逻辑缺陷所以检查了很久才ac的一道。

By using of self-defined comparator, we can sort intervals due to their starts.

Thanks to dashen

/**
 * Definition for an interval.
 * public class Interval {
 *     int start;
 *     int end;
 *     Interval() { start = 0; end = 0; }
 *     Interval(int s, int e) { start = s; end = e; }
 * }
 */
import java.util.ArrayList;
import java.util.Collections;
import java.util.Comparator;
public class Solution {
    

	//ArrayList<Type> name
public ArrayList<Interval> merge(ArrayList<Interval> intervals) {
         ArrayList<Interval> res = new ArrayList<Interval>();
         int i = 1;
         int len = intervals.size();                                      //.size
         if(len <=1 || intervals == null){
        	 return intervals;
         }
                                         //.get
         Collections.sort(intervals, new startsComparator());
         Interval first = intervals.get(0); 
         
         while(i<len){
        	 Interval next = intervals.get(i);
        	 
        	 if(first.end>=next.start && first.end<next.end) {
        		 Interval merge = new Interval(first.start,next.end);
        		 //res.add(merge);
        		 first = merge;
        		 i++;
        	 }
        	 else if(first.end>=next.start && first.end>=next.end){
        	    Interval merge = new Interval(first.start,first.end);
        		 //res.add(merge);
        		 first = merge;
        		 i++;
        		
        	 }else{
        	     res.add(first);
        		 first = next;
        		 i++;
        	 }
        	 /*
        	 if (first.end >= next.start) {
        	     first.start = Math.min(first.start, next.start);
        	     first.end = Math.max(first.end, next.end);
        	     i++;
        	 } else {
        	     res.add(first);
        	     first = next;
        	     i++;
        	 }
        	 */
            
         }
         res.add(first);
         return res;
    }


 class startsComparator implements Comparator<Interval> {

	//ascending order;
	 @Override
	public int compare(Interval i1, Interval i2) {
		// TODO Auto-generated method stub
		int s1 = i1.start;
		int s2 = i2.start;		
		if(s1>s2){
			return 1;
		} else if (s1==s2) {
		    return 0;
		}
		else {
			return -1;
		}
	}
	
}
	

    
    }

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值