Merge Intervals

本文介绍了一种合并重叠区间的算法实现,通过排序和合并步骤处理输入的区间集合,最终返回合并后的区间列表。示例中给出了具体的代码实现及运行过程。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

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

 

       思路:本题的难度虽然是hard,但是实际上比较简单,就是先排序,后合并。下面的代码使用了realloc(584 ms),如果直接使用malloc分配足够的内存,结果竟然会变慢(692 ms),呵呵。代码如下:

struct Interval
{
    int start;
    int end;
};
 
int compar(constvoid *a, const void *b)
{
    return  ((struct Interval *)a)->start- ((struct Interval *)b)->start;
}
 
struct Interval*merge(struct Interval* intervals, int intervalsSize,int* returnSize)
{
    int i;
    int laststart, lastend;
    struct Interval *res = NULL;
    int reslen = 0;
 
    if(intervalsSize == 0)  return res;
    qsort(intervals, intervalsSize,sizeof(struct Interval), compar);
 
    laststart = intervals[0].start;
    lastend = intervals[0].end;
   
    for(i = 1; i <intervalsSize; i++)
    {
        if(intervals[i].start<= lastend)
        {
            if(lastend < intervals[i].end)
            {
                lastend = intervals[i].end;
            }
        }
        else
        {
            reslen++;
            res = realloc(res,reslen*sizeof(struct Interval));
            res[reslen-1].start= laststart;
            res[reslen-1].end= lastend;
 
            laststart = intervals[i].start;
            lastend = intervals[i].end;
        }
    }
   
    reslen++;
    res = realloc(res, reslen*sizeof(structInterval));
    res[reslen-1].start =laststart;
    res[reslen-1].end =lastend;
 
    *returnSize = reslen;
    return res;
}
 


转载于:https://www.cnblogs.com/gqtcgq/p/7247132.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值