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].

思路一

先对 intervals 按 start 排序,再合并相邻的。

因为 leetcode 好像不支持 sort( v.begin(), v.end(), cmp ); 的三参格式的sort。所以我就写了一个。

/**
 * Definition for an interval.
 * struct Interval {
 *     int start;
 *     int end;
 *     Interval() : start(0), end(0) {}
 *     Interval(int s, int e) : start(s), end(e) {}
 * };
 */
class Solution {
public:
    void mysort(vector<Interval> &intervals)
    {
        int num = intervals.size();
        for(int i=0;i<num-1;i++)
            for(int j=i+1;j<num;j++)
                if(intervals[i].start>intervals[j].start)
                {
                    Interval tmp = intervals[i];
                    intervals[i] = intervals[j];
                    intervals[j] = tmp;
                }
    }

    vector<Interval> merge(vector<Interval> &intervals) {
        // Start typing your C/C++ solution below
        // DO NOT write int main() function
        vector<Interval> result;
        int num = intervals.size();
        if(num<=1)
            return intervals;
        mysort(intervals);
        Interval myinter = intervals[0];
        Interval newinter;
        int i=1;
        while(i<num)
        {
            Interval tmp = intervals[i];
            newinter.start = min(myinter.start,tmp.start);
            if(myinter.end>=tmp.start)  //have interaction
            {       
                if(myinter.end<=tmp.end)
                    newinter.end = tmp.end;
                else
                    newinter.end = myinter.end;
                myinter = newinter;
            }   
            else
            {
                result.push_back(myinter);
                myinter = tmp;
            }
            i++;
        }  
        result.push_back(myinter);
        return result;
    }   
    
};


思路二

这里我们就不需要再排序了,而是用类似于插入排序的思想,依次将第 i 个interval 插入到前面 i-1 个intervals 已经形成的结果intervals 中。

/**
 * Definition for an interval.
 * struct Interval {
 *     int start;
 *     int end;
 *     Interval() : start(0), end(0) {}
 *     Interval(int s, int e) : start(s), end(e) {}
 * };
 */
class Solution {
public:
    vector<Interval> merge(vector<Interval> &intervals) {
        // Start typing your C/C++ solution below
        // DO NOT write int main() function
        vector<Interval> result;
        for(int i=0;i<intervals.size();i++)
        {
            insert(result,intervals[i]);
        }
        return result;
    }
    
    void insert(vector<Interval> &intervals, Interval newInterval) {  
        // Start typing your C/C++ solution below   
        // DO NOT write int main() function   
        int i=0;  
        for(i=0;i<intervals.size();i++)  
        {  
            if(newInterval.start>intervals[i].end)  
                continue ;  
            if(newInterval.end<intervals[i].start)  
            {  
                intervals.insert(intervals.begin()+i,1,newInterval);  
                return ;  
            }  
            else if(newInterval.end<intervals[i].end)  
                 {  
                     intervals[i].start = min(newInterval.start,intervals[i].start);  
                     return ;  
                 }  
                 else  
                 {  
                     newInterval.start = min(newInterval.start,intervals[i].start);  
                     intervals.erase(intervals.begin()+i);  
                     i--;  
                 }  
        }   
        intervals.insert(intervals.begin()+i, 1, newInterval);  
        return ;  
    }  
    
};

 

最新 java

/**
 * 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; }
 * }
 */
public class Solution {
    public List<Interval> merge(List<Interval> intervals) {
        List<Interval> result = new ArrayList<Interval>();
        if(intervals == null || intervals.size() == 0){
            return result;
        }
        Collections.sort(intervals, new Comparator<Interval>() {
        	public int compare(Interval i1, Interval i2) {
        		return i1.start - i2.start;
        	}
        });
        Interval pre = intervals.get(0);
        for(int i=1; i<intervals.size(); i++){
            Interval cur = intervals.get(i);
            if(pre.end < cur.start){
                result.add(pre);
                pre = cur;
            } else {
                Interval merge = new Interval(pre.start, Math.max(pre.end, cur.end));
                pre = merge;
            }
        }
        result.add(pre);
        return result;
    }
}




  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
这段代码存在以下问题: 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、付费专栏及课程。

余额充值