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

新闻门户网站什么意思网络加速器手机版

新闻门户网站什么意思,网络加速器手机版,利用网站空间做代理,wordpress全站ajax插件57. 插入区间 插入区间 给你一个无重叠的 ,按照区间起始端点排序的区间列表。 在列表中插入一个新的区间,你需要确保列表中的区间仍然有序且不重叠(如果有必要的话,可以合并区间)。 示例 1: 输入&#x…

57. 插入区间

插入区间
给你一个无重叠的 ,按照区间起始端点排序的区间列表。
在列表中插入一个新的区间,你需要确保列表中的区间仍然有序且不重叠(如果有必要的话,可以合并区间)。

示例 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] 重叠。

示例 3:

输入:intervals = [], newInterval = [5,7]
输出:[[5,7]]

示例 4:

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

示例 5:

输入:intervals = [[1,5]], newInterval = [2,7]
输出:[[1,7]]

提示:

0 <= intervals.length <= 104
intervals[i].length = 2
0 <= intervals[i][0] <= intervals[i][1] <= 105
intervals 根据 intervals[i][0] 按 升序 排列
newInterval.length = 2
0 <= newInterval[0] <= newInterval[1] <= 105

思路

最开始的思路就是,先把新的区间按照起点的顺序插入到旧区间内,之后对所有区间进行判断,来将可以合并的区间合并起来。但是如果直接这样做的话,因为插入的时候需要将所有元素后移一位,而对于区间合并,每次合并后都需要删除一个元素,导致每次需要将所有元素前移一位,这样的在后面测试案例较大的时候是没法通过的。因此需要别的思路来解决这几个问题。 除此之外,还需要知道,有两个区间(a,b),(c,d),当发现c<b的时候,说明两个区间需要合并。并且合并后的区间是(a,max(b,d))。

解题方法

创建一个ans来保存最后的区间列表,第一步,将新的区间插入到旧区间内,这里采用,遍历旧区间intervals,通过判断newInterval的起点大小,把小于newInterval起点的区间放进ans中,当发现不满足的时候,就是该放入newInterval的位置了,这个时候就可以把newInterval加入ans中。这样就做到了将newInterval插入到旧区间内。 第二步,进行判断新插入的区间newInterval是否需要合并,与ans中最后一个区间进行判断(此时newInterval还没有插入ans中),如果需要合并那么直接合并就行了,也就不需要newInterval插入了。 第三步,在把新的区间newInterval放入(包括合并)后,就需要把intervals剩下的区间加入ans中了,不过在加入的时候需要进行判断,如果需要合并,那么直接合并。如果不需要合并,只需要加入剩下的区间了。 第四步,在第三步之前,考虑了一个特殊情况,也就是新区间是是放入最后一个位置,这个时候需要单独把newInterval放入ans后,并且判断是否需要合并。

复杂度

时间复杂度:
O(n)

空间复杂度:
O(n)

Code

class Solution {
public:vector<vector<int>> insert(vector<vector<int>>& intervals, vector<int>& newInterval) {vector<vector<int>> ans;if(intervals.size()==0){intervals.push_back(newInterval);return intervals;}int i=0,k=0;//找到新区间应该放置在旧区间的位置for(;i<intervals.size();++i){if(newInterval[0]<=intervals[i][0]){if(i>0&&newInterval[0]<=intervals[i-1][1]){ans[i-1][1]=max(ans[i-1][1],newInterval[1]);k=i-1;}else{k=i;ans.push_back(newInterval);}break;}ans.push_back(intervals[i]);}//如果新的区间放在最后一个位置if(i==intervals.size()){if(newInterval[0]<=intervals[i-1][1]){ans[i-1][1]=max(ans[i-1][1],newInterval[1]);}else{ans.push_back(newInterval);}}//新的区间放在了旧区间中for(;i<intervals.size();++i){if(ans[k][1]>=intervals[i][0]){ans[k][1]=max(ans[k][1],intervals[i][1]);}else{ans.push_back(intervals[i]);}}return ans;}
};
http://www.yayakq.cn/news/949349/

相关文章:

  • 网站建设的成本分析python做网站有什么弊端
  • 网站开发新技术探索有免费的网站做农家院宣传
  • 怎么做微信里的网站链接在线制作流程图网页
  • 做外贸怎样打开国外网站在苏州找学生做家教在哪个网站
  • 长春怎么注册网站平台做中介网站需要多少钱
  • 教育网站制作哪家服务好中国十大科技公司排名
  • 深圳专业做网站的公司哪家好公共资源交易网站建设方案
  • 国外无版权图片网站总结什么是网络营销
  • 建设适应连锁行业网站app制作软件企业
  • 外贸网站建设制作教程网站建设属于什么行业
  • 苏州网站优化企业网站怎么容易被百度收录
  • 网站设计公司青岛济南做网站互联网公司
  • 网站解析加速制作网站模板
  • 简单的个人网站html织梦网站系统删除
  • 网站建设服务非常好湖南岚鸿公司网站万能密码修复
  • 国外的一些网站现有的网站开发技术
  • 六安网站建设全包自助建站免费申请个人网页
  • 做网站价格需要多少钱flash网站开发
  • 浙江省住房与城乡建设部网站wordpress 语种顺序
  • vs2010做网站低价手机网站建设
  • 住房和城乡建设部网站建筑合同网络营销策略论文
  • 网站建设考察试卷繁峙做网站建设
  • 网站建设丨找王科杰效果好500万在北京几环买房
  • 武威网站建设iis网站搭建
  • 成都公司建站模板东昌网站建设费用
  • 宁波江北区网站推广联系方式别人在百度冒用公司旗号做网站
  • 网站风格设计甘肃建设监理协会网站
  • 怎么做多个网站单点登录设计师网站1688
  • 徐州网站seo公司网络市场营销
  • 做淘宝主要看哪些网站有哪些内容wordpress仿站步骤