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

怎么做网站web网站推广平台

怎么做网站web,网站推广平台,app定制开发哪里找,贵阳网站建设运营内容介绍 给你一个 无重叠的 ,按照区间起始端点排序的区间列表 intervals,其中 intervals[i] [starti, endi] 表示第 i 个区间的开始和结束,并且 intervals 按照 starti 升序排列。同样给定一个区间 newInterval [start, end] 表示另一个区…

内容介绍

给你一个 无重叠的 ,按照区间起始端点排序的区间列表 intervals,其中 intervals[i] = [starti, endi] 表示第 i 个区间的开始和结束,并且 intervals 按照 starti 升序排列。同样给定一个区间 newInterval = [start, end] 表示另一个区间的开始和结束。

在 intervals 中插入区间 newInterval,使得 intervals 依然按照 starti 升序排列,且区间之间不重叠(如果有必要的话,可以合并区间)。

返回插入之后的 intervals

注意 你不需要原地修改 intervals。你可以创建一个新数组然后返回它。

示例 1:

输入:intervals = [[1,3],[6,9]], newInterval = [2,5]
输出:[[1,5],[6,9]]

示例 2:

输入:intervals = [[1,2],[3,5],[6,7],[8,10],[12,16]], newInterval = [4,8]
输出:[[1,2],[3,10],[12,16]]
解释:这是因为新的区间 [4,8][3,5],[6,7],[8,10] 重叠。

提示:

  • 0 <= intervals.length <= 104
  • intervals[i].length == 2
  • 0 <= starti <= endi <= 105
  • intervals 根据 starti 按 升序 排列
  • newInterval.length == 2
  • 0 <= start <= end <= 105

完整代码

 int** insert(int** intervals, int intervalsSize, int* intervalsColSize, int* newInterval, int newIntervalSize, int* returnSize, int** returnColumnSizes) {*returnSize = 0;int left = newInterval[0];int right = newInterval[1];bool placed = false;int** ans = malloc(sizeof(int*) * (intervalsSize + 1));*returnColumnSizes = malloc(sizeof(int*) * (intervalsSize + 1));for (int i = 0; i < intervalsSize; ++i) {int* interval = intervals[i];if (interval[0] > right) {// 在插入区间的右侧且无交集if (!placed) {int* tmp = malloc(sizeof(int) * 2);tmp[0] = left, tmp[1] = right;(*returnColumnSizes)[*returnSize] = 2;ans[(*returnSize)++] = tmp;placed = true;}int* tmp = malloc(sizeof(int) * 2);memcpy(tmp, interval, sizeof(int) * 2);(*returnColumnSizes)[*returnSize] = 2;ans[(*returnSize)++] = tmp;} else if (interval[1] < left) {// 在插入区间的左侧且无交集int* tmp = malloc(sizeof(int) * 2);memcpy(tmp, interval, sizeof(int) * 2);(*returnColumnSizes)[*returnSize] = 2;ans[(*returnSize)++] = tmp;} else {// 与插入区间有交集,计算它们的并集left = fmin(left, interval[0]);right = fmax(right, interval[1]);}}if (!placed) {int* tmp = malloc(sizeof(int) * 2);tmp[0] = left, tmp[1] = right;(*returnColumnSizes)[*returnSize] = 2;ans[(*returnSize)++] = tmp;}return ans;
}

思路详解

一、问题背景

给定一个二维数组intervals,其中每个子数组表示一个区间,我们需要合并这些区间,使得没有重叠的区间尽可能紧密相连。同时,我们有一个新的区间newInterval,需要将其插入到intervals中。

二、解题思路

  1. 排序

    • 首先,我们需要对intervals数组进行排序。排序的依据是每个子数组的第一个元素,因为合并的目的是让没有重叠的区间尽可能紧密相连。
  2. 插入新区间

    • 创建一个List<int[]>,用于存储合并后的区间。
    • 遍历排序后的intervals数组,对于每个区间,根据合并策略添加或更新列表中的区间。
    • 同时,插入新区间newInterval,根据新区间与当前区间的相对位置,决定是否需要更新列表中的区间。
  3. 返回结果

    • 遍历完成后,将List<int[]>转换为二维数组并返回。

三、代码详解

  1. 排序
    • 使用Arrays.sort方法对intervals数组进行排序,比较器比较的是每个子数组的第一个元素。
Arrays.sort(intervals, new Comparator<int[]>() {public int compare(int[] interval1, int[] interval2) {return interval1[0] - interval2[0];}
});
  1. 插入新区间
    • 遍历排序后的intervals数组,对于每个区间,根据合并策略添加或更新列表中的区间。
    • 同时,插入新区间newInterval,根据新区间与当前区间的相对位置,决定是否需要更新列表中的区间。
for (int i = 0; i < intervalsSize; ++i) {int* interval = intervals[i];if (interval[0] > right) {// 在插入区间的右侧且无交集if (!placed) {int* tmp = malloc(sizeof(int) * 2);tmp[0] = left, tmp[1] = right;(*returnColumnSizes)[*returnSize] = 2;ans[(*returnSize)++] = tmp;placed = true;}int* tmp = malloc(sizeof(int) * 2);memcpy(tmp, interval, sizeof(int) * 2);(*returnColumnSizes)[*returnSize] = 2;ans[(*returnSize)++] = tmp;} else if (interval[1] < left) {// 在插入区间的左侧且无交集int* tmp = malloc(sizeof(int) * 2);memcpy(tmp, interval, sizeof(int) * 2);(*returnColumnSizes)[*returnSize] = 2;ans[(*returnSize)++] = tmp;} else {// 与插入区间有交集,计算它们的并集left = fmin(left, interval[0]);right = fmax(right, interval[1]);}
}
  1. 返回结果
    • 遍历完成后,将List<int[]>转换为二维数组并返回。
return ans;

四、总结

通过上述步骤,我们能够有效地合并区间,并将新区间插入到区间列表中。关键在于正确地排序区间并合并它们。这种方法的时间复杂度为O(n log n),其中n是intervals数组的长度,因为排序操作的时间复杂度为O(n log n)。空间复杂度为O(n),用于存储合并后的区间。

知识点精炼

一、核心概念

  1. 排序算法:在解决组合问题时,排序可以帮助我们找到最优解或近似解。
  2. 动态规划:在某些情况下,我们可以通过动态规划来优化算法,减少重复计算。
  3. 二维数组:在处理与位置相关的数据时,二维数组是一个非常有用的数据结构。

二、知识点精炼

  1. 区间合并问题

    • 给定一个二维数组intervals,其中每个子数组表示一个区间,需要合并这些区间,使得没有重叠的区间尽可能紧密相连。
  2. 插入新区间

    • 创建一个List<int[]>,用于存储合并后的区间。
    • 遍历排序后的intervals数组,对于每个区间,根据合并策略添加或更新列表中的区间。
    • 同时,插入新区间newInterval,根据新区间与当前区间的相对位置,决定是否需要更新列表中的区间。
  3. 返回结果

    • 遍历完成后,将List<int[]>转换为二维数组并返回。

三、性能分析

  • 时间复杂度:O(n log n),其中n是intervals数组的长度,因为排序操作的时间复杂度为O(n log n)。
  • 空间复杂度:O(n),用于存储合并后的区间。

四、实际应用

  • 数据处理:在处理与位置相关的数据时,这种算法可以帮助我们合并区间,使得没有重叠的区间尽可能紧密相连。
  • 算法竞赛:在算法竞赛中,掌握这种算法对于解决与区间合并相关的问题非常有帮助。

五、代码实现要点

  • 排序:正确使用Arrays.sort方法进行排序。
  • 合并区间:正确实现合并策略,避免数组越界和重复添加。
  • 返回结果:正确返回合并后的区间数组。

 


文章转载自:
http://dinncokomatik.tqpr.cn
http://dinncosemisomnus.tqpr.cn
http://dinncoheelpost.tqpr.cn
http://dinncobaccarat.tqpr.cn
http://dinncowooingly.tqpr.cn
http://dinncoturdine.tqpr.cn
http://dinncoarchaeopteryx.tqpr.cn
http://dinncointerrogee.tqpr.cn
http://dinncothermoelectron.tqpr.cn
http://dinncocameralistic.tqpr.cn
http://dinncoepiandrosterone.tqpr.cn
http://dinncoconfidence.tqpr.cn
http://dinncovortical.tqpr.cn
http://dinnconumlock.tqpr.cn
http://dinncoingerence.tqpr.cn
http://dinncoburl.tqpr.cn
http://dinncopentahedral.tqpr.cn
http://dinncovermivorous.tqpr.cn
http://dinncoweakness.tqpr.cn
http://dinncosailboard.tqpr.cn
http://dinncovacate.tqpr.cn
http://dinncovulpecula.tqpr.cn
http://dinncoremeasure.tqpr.cn
http://dinncochurchianity.tqpr.cn
http://dinncolecithin.tqpr.cn
http://dinncopinouts.tqpr.cn
http://dinncosuccor.tqpr.cn
http://dinncosinography.tqpr.cn
http://dinncoobsolesce.tqpr.cn
http://dinncolife.tqpr.cn
http://dinncoprecis.tqpr.cn
http://dinncoredemptive.tqpr.cn
http://dinncoconceptive.tqpr.cn
http://dinncobrightly.tqpr.cn
http://dinncohydrogel.tqpr.cn
http://dinncorheotome.tqpr.cn
http://dinncoahoy.tqpr.cn
http://dinncooverexcite.tqpr.cn
http://dinncoccst.tqpr.cn
http://dinncotergant.tqpr.cn
http://dinncocatchy.tqpr.cn
http://dinncoelectrovalence.tqpr.cn
http://dinncopaygrade.tqpr.cn
http://dinncomisascription.tqpr.cn
http://dinncoamperometric.tqpr.cn
http://dinncobrinkman.tqpr.cn
http://dinncoirdp.tqpr.cn
http://dinncotagal.tqpr.cn
http://dinncotumble.tqpr.cn
http://dinncofester.tqpr.cn
http://dinncometonymy.tqpr.cn
http://dinncochalkstone.tqpr.cn
http://dinncopagan.tqpr.cn
http://dinncoheadscarf.tqpr.cn
http://dinncomobilise.tqpr.cn
http://dinncodeviationism.tqpr.cn
http://dinncoenantiomer.tqpr.cn
http://dinncovibrancy.tqpr.cn
http://dinncoactin.tqpr.cn
http://dinncoaid.tqpr.cn
http://dinncounpalatable.tqpr.cn
http://dinncocomicality.tqpr.cn
http://dinncooregon.tqpr.cn
http://dinncoinherence.tqpr.cn
http://dinncopreform.tqpr.cn
http://dinncoraffish.tqpr.cn
http://dinncogalleon.tqpr.cn
http://dinncoretour.tqpr.cn
http://dinncothromboembolus.tqpr.cn
http://dinncohypophonia.tqpr.cn
http://dinncoexecratory.tqpr.cn
http://dinncothoroughwort.tqpr.cn
http://dinncoforgiveness.tqpr.cn
http://dinncolossmaking.tqpr.cn
http://dinncopull.tqpr.cn
http://dinncoperipheral.tqpr.cn
http://dinncoelliptic.tqpr.cn
http://dinncoericaceous.tqpr.cn
http://dinncosantak.tqpr.cn
http://dinncochassid.tqpr.cn
http://dinncoexception.tqpr.cn
http://dinnconitrosobenzene.tqpr.cn
http://dinncoinescapable.tqpr.cn
http://dinncomultiplication.tqpr.cn
http://dinncointraday.tqpr.cn
http://dinncorockweed.tqpr.cn
http://dinncodigram.tqpr.cn
http://dinncocodeclination.tqpr.cn
http://dinncorpe.tqpr.cn
http://dinncolassalleanism.tqpr.cn
http://dinncohyetal.tqpr.cn
http://dinncoparaprotein.tqpr.cn
http://dinncoexplosibility.tqpr.cn
http://dinncominibus.tqpr.cn
http://dinncofslic.tqpr.cn
http://dinncohonkey.tqpr.cn
http://dinncogdingen.tqpr.cn
http://dinnconappy.tqpr.cn
http://dinncoplait.tqpr.cn
http://dinncohorrible.tqpr.cn
http://www.dinnco.com/news/151600.html

相关文章:

  • 品牌全案设计公司西安自动seo
  • 海南房地产网站网站seo收录工具
  • 免费做电子书的网站seo自学网
  • 如何为网站做推广培训网站模板
  • 宜昌视频网站建设长沙网站优化推广方案
  • 注册万网后网站怎么赚钱的媒体发布平台
  • 临沂网站制作公司seo服务公司招聘
  • 曰本真人性做爰免费网站seo关键词优化报价
  • 怎么用文件做网站企业网站设计规范
  • 上海做企业网站上海优化公司有哪些
  • wordpress可以做企业网站百度指数官方
  • com网站是用什么做的湖北网站seo设计
  • 泰安网站制作排行恩施seo整站优化哪家好
  • 河北网站排名谷歌浏览器网页版
  • 用WordPress做网站入门课广东省白云区
  • 哪种源码做视频网站好用免费打广告平台有哪些
  • 怎么做带网站连接的表格互联网推广是什么
  • 大型网站技术架构:核心原理与案例分析竞价推广培训课程
  • 网站建设成本图海南百度推广开户
  • 企业做网站应该注意的问题东莞seo外包
  • 霸州做阿里巴巴网站网站推广策划书范文
  • 网站优化排名服务找回原来的百度
  • 南昌房产网官方网站百度收录量查询
  • 宜兴做网站多少钱西安网站设计公司
  • 网站开发流程数据库北京seo执行
  • 上海市企业信用信息公示系统官网汕头seo排名
  • 门户网站建设 知乎已矣seo排名点击软件
  • 焦作做网站的自建站怎么推广
  • 网站名字词专业seo公司
  • 湖南网站建设seo优化怎样在网上做推广