当前位置: 首页 > news >正文

红河优才网站建设友情链接代码

红河优才网站建设,友情链接代码,乐从狮山网站建设,成都广告公司文章目录力扣56.合并区间题目描述排序合并力扣56.合并区间 题目描述 以数组 intervals 表示若干个区间的集合,其中单个区间为 intervals[i] [starti, endi] 。请你合并所有重叠的区间,并返回 一个不重叠的区间数组,该数组需恰好覆盖输入中…

文章目录

  • 力扣56.合并区间
    • 题目描述
    • 排序合并

力扣56.合并区间

题目描述

以数组 intervals 表示若干个区间的集合,其中单个区间为 intervals[i] = [starti, endi] 。请你合并所有重叠的区间,并返回 一个不重叠的区间数组,该数组需恰好覆盖输入中的所有区间 。

示例 1:

输入:intervals = [[1,3],[2,6],[8,10],[15,18]]
输出:[[1,6],[8,10],[15,18]]
解释:区间 [1,3] 和 [2,6] 重叠, 将它们合并为 [1,6].
示例 2:

输入:intervals = [[1,4],[4,5]]
输出:[[1,5]]
解释:区间 [1,4] 和 [4,5] 可被视为重叠区间。

提示:

1 <= intervals.length <= 104
intervals[i].length == 2
0 <= starti <= endi <= 104

排序合并

排序合并的思想力扣官方的解答蛮好的,可以直接点下面链接看一下,这里我偷个懒只提供官方没有给出的C语言代码实现:
力扣官方思路链接

官解搬运:
如果我们按照区间的左端点排序,那么在排完序的列表中,可以合并的区间一定是连续的。如下图所示,标记为蓝色、黄色和绿色的区间分别可以合并成一个大区间,它们在排完序的列表中是连续的:

在这里插入图片描述

算法:

我们用数组 merged 存储最终的答案。

首先,我们将列表中的区间按照左端点升序排序。然后我们将第一个区间加入 merged 数组中,并按顺序依次考虑之后的每个区间:

  • 如果当前区间的左端点在数组 merged 中最后一个区间的右端点之后,那么它们不会重合,我们可以直接将这个区间加入数组 merged 的末尾;

  • 否则,它们重合,我们需要用当前区间的右端点更新数组 merged 中最后一个区间的右端点,将其置为二者的较大值。

C语言版代码实现(冒泡排序版本)

/*** Return an array of arrays of size *returnSize.* The sizes of the arrays are returned as *returnColumnSizes array.* Note: Both returned array and *columnSizes array must be malloced, assume caller calls free().*/
int** merge(int** intervals, int intervalsSize, int* intervalsColSize, int* returnSize, int** returnColumnSizes){int i,j,pre=-1,*t,base=100;int **results=(int **)malloc(sizeof(int *)*base);*returnColumnSizes=(int *)malloc(sizeof(int)*intervalsSize);*returnSize=0;for(i=1;i<intervalsSize;i++){for(j=0;j<intervalsSize-i;j++){if(intervals[j][0]>intervals[j+1][0]){t=intervals[j];intervals[j]=intervals[j+1];intervals[j+1]=t;}}}for(i=0;i<intervalsSize;i++){if(intervals[i][0]>pre){results[*(returnSize)]=(int *)calloc(sizeof(int),2);(*returnColumnSizes)[*returnSize]=2;results[(*returnSize)][0]=intervals[i][0];results[(*returnSize)++][1]=intervals[i][1];pre=intervals[i][1];if(*returnSize==base){base*=2;results=(int **)realloc(results,sizeof(int *)*base);}}else{results[(*returnSize)-1][1]=fmax(intervals[i][1], results[(*returnSize)-1][1]);pre=results[(*returnSize)-1][1];}}return results;
}
http://www.15wanjia.com/news/165502.html

相关文章:

  • 网站建设的功能模型wordpress和网盘结合
  • 私人做网站有什么用微信小程序开店需要多少钱
  • 网站关键词字数北京seo排名
  • 视频网站的嵌入代码是什么WordPress显示403
  • 航天基地规划建设局网站昆明建设局网站
  • 自适应网站建设优化建站网站开发时保证用户登陆的安全
  • 广东住房和建设局网站官网中山市建设局网站窗口电话
  • 怎么做的360网站打不开贵阳网站建设-中国互联
  • nas服务器 做网站营销推广工作内容
  • vs2010 iis 网站开发豪华网站建设方案
  • 建设银行山西招聘网站一些建筑设计网站
  • 好看怎么上传视频网站吗西宁网站制作多少钱
  • 网站所有二级目录济南网站建设推荐搜点网络NO1
  • 在什么网站做贸易好制作php网站
  • 网站建设的一般步骤包括哪些30天网站建设 视频教程
  • 用什么网站开发巴西客户网络网页制作
  • 如何给网站做轮播图网站策划师招聘
  • zencart 一个产品网站下单wordpress外部调用插件
  • 网站建设公司谁管东莞手机网站建设
  • 百度推广网站一年多少钱网络科技公司都是干嘛的
  • 邯郸建站公司wap网站 开发
  • 模板建站总公司网站搭建修改收费依据
  • jsp网站开发介绍后端开发培训机构
  • 城阳建网站友情链接
  • 网站改版方案明星个人网站设计模板
  • 刷单网站建设专业旅游网站制作
  • 网站设计规划的一般流程榆林电商网站建设
  • 公司高端网站建设网站的建设初步定位
  • 比较公司网站与营销网站的不同wordpress 左图右文
  • 东平做网站如何用源码搭建网站