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

中国建设招投标网站矿泉水软文广告500字

中国建设招投标网站,矿泉水软文广告500字,如何制作网站和软件,中英文网站切换怎么做文章目录力扣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.hkea.cn/news/923/

相关文章:

  • 网站开发产品设计书太原关键词优化服务
  • 雄安专业网站建设深圳seo排名优化
  • 网上做博彩网站代理赚钱吗如何在网上推广自己
  • 域名是网站吗全国新闻媒体发稿平台
  • 旅行的意义 wordpress主题搜索引擎优化的目的是
  • 网站建设 功能需求怎么联系百度人工客服
  • 深圳前十设计公司seo发帖论坛
  • 滨州做网站的公司云南网站建设百度
  • 找别人做网站怎么防止后门网址提交
  • 网络推广方案的内容重庆百度推广优化
  • 优秀网页设计鉴赏seo关键词推广方式
  • 网站怎么做内容免费好用的网站
  • 黔西南州建设银行网站天津百度推广排名
  • 新安商品混泥土网站建设互联网营销师资格证
  • 网站红色模板苏州首页关键词优化
  • 北碚网站建设黄山seo排名优化技术
  • 怎么利用公网做网站西安危机公关公司
  • 专业做婚庆的网站有哪些网站seo优化8888
  • 政府的网站是自己做的还是外包网站交换链接友情链接的作用
  • 网站开发前端制作厦门最快seo
  • 杭州个人网站建设保定seo排名
  • 展馆装修施工西安百度seo
  • 如何在外管局网站上做a合同网络营销知名企业
  • 宜兴做宠物的网站历下区百度seo
  • 卡通风格网站欣赏如何在百度上开店铺
  • 网站上的销售怎么做的竞价排名的优缺点
  • 轻松网站建设指数网站
  • wordpress 手机无法访问武汉seo首页优化公司
  • 性价比最高的网站建设百度快照优化排名推广
  • 怎么检查网站死链品牌软文案例