Merge Intervals

ref http://www.cnblogs.com/springfor/p/3872332.html


1) 要先排序,按照start, 怎么写comparator是关键 class IntervalComparator implements Comparator<Interval> {

2) 然后按照end 在主程序里merge,

public class Solution {
    // ref http://www.cnblogs.com/springfor/p/3872332.html
    public ArrayList<Interval> merge(ArrayList<Interval> intervals) {
        if(intervals==null || intervals.size()<=1) return intervals;
        
        Collections.sort(intervals, new IntervalsComparator());
        
        ArrayList<Interval> res = new  ArrayList<Interval>();
        Interval pre = intervals.get(0);
        
        for(int i=0; i< intervals.size(); i++){
            Interval cur = intervals.get(i);
            if(pre.end>=cur.start){     // == 也要考虑哟
                Interval merged = new Interval(pre.start, Math.max(pre.end, cur.end));
                pre = merged;
            }else{
                res.add(pre);   
                pre = cur;       
            }
        }
        
        res.add(pre);           // 不要忘了最后一个pre
        return res;
    }
    
    class IntervalsComparator implements Comparator<Interval>{// class IntervalComparator implements Comparator<Interval> {
        public int compare(Interval i1, Interval i2){
            return i1.start- i2.start;
        }
    }
}


这段代码存在以下问题: 1. 在函数开头定义了一个变量 `c`,但是没有给它赋初值,应该改为 `int c = *intervalsColSize`,以获取列数。 2. 第二个 `for` 循环中的循环条件应该改为 `j < intervalsSize - 1`,以防止数组越界。 3. 第三个 `for` 循环中应该先判断 `k < intervalsSize` 再进行数组操作,以防止数组越界。 4. `returnColumnSizes` 数组应该在函数开头先进行动态内存分配,以确保其有足够的空间存储每个子数组的列数。 5. 在最后返回结果时,应该返回一个新的二维数组,而不是原来的 `intervals` 数组,因为原来的数组已经被修改了。 6. 在返回结果时,应该将 `returnSize` 指向的地址赋值为 `intervalsSize`,而不是赋值为 `&intervalsSize`。 综上所述,修改后的代码如下所示: ``` int** merge(int** intervals, int intervalsSize, int* intervalsColSize, int* returnSize, int** returnColumnSizes) { int c = *intervalsColSize; int** res = (int**)malloc(intervalsSize * sizeof(int*)); *returnColumnSizes = (int*)malloc(intervalsSize * sizeof(int)); int idx = 0; for (int i = 0; i < intervalsSize; i++) { int start = intervals[i][0], end = intervals[i][c - 1]; for (int j = i + 1; j < intervalsSize; j++) { if (intervals[j][0] <= end) { end = fmax(end, intervals[j][c - 1]); i++; } else { break; } } int* interval = (int*)malloc(c * sizeof(int)); interval[0] = start; interval[c - 1] = end; res[idx] = interval; (*returnColumnSizes)[idx] = c; idx++; } *returnSize = idx; return res; } ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值