zoukankan      html  css  js  c++  java
  • Leetcode 57. 插入区间

    地址 https://leetcode-cn.com/problems/insert-interval/

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

    解法 模拟 遍历已经记录排序的区间 有以下几种情况
    1 未插入 当前的区间和插入的区间无交集 插入区间在前
    插入区间 记录当前区间

    2 未插入 当前的区间和插入的区间无交集 插入区间在后
    记录当前区间 插入区间情况不明 需要和后继区间比较才能明确处理

    3 未插入 当前区间和插入区间有交集
    合并插入区间和当前区间 插入区间情况不明 需要和后继区间比较才能明确处理

    4 插入区间已经插入
    记录当前区间即可

    class Solution {
    public:
    	vector<vector<int>> ans;
    	vector<vector<int>> insert(vector<vector<int>>& intervals, vector<int>& newInterval) {
    		int insert = 0;
    		for (int i = 0; i < intervals.size(); i++) {
    			if (0 == insert && newInterval[1] < intervals[i][0]) {
    				ans.push_back(newInterval); ans.push_back(intervals[i]);
    				insert = 1;
    			}
    			else if (newInterval[0] > intervals[i][1]) {
    				ans.push_back(intervals[i]);
    			}
    			else if (0 == insert && (newInterval[0] <= intervals[i][1] || intervals[i][0] <= newInterval[1])) {
    				//合并
    				newInterval[0] = min(newInterval[0], intervals[i][0]);
    				newInterval[1] = max(newInterval[1], intervals[i][1]);
    			}
    			else if (1 == insert) {
    				ans.push_back(intervals[i]);
    			}
    		}
    		if (0 == insert) {
    			ans.push_back(newInterval);
    		}
    
    		return ans;
    	}
    };
    

    我的视频题解空间

    作 者: itdef
    欢迎转帖 请保持文本完整并注明出处
    技术博客 http://www.cnblogs.com/itdef/
    B站算法视频题解
    https://space.bilibili.com/18508846
    qq 151435887
    gitee https://gitee.com/def/
    欢迎c c++ 算法爱好者 windows驱动爱好者 服务器程序员沟通交流
    如果觉得不错,欢迎点赞,你的鼓励就是我的动力
    阿里打赏 微信打赏
  • 相关阅读:
    Linux 自定义快捷命令
    Linux 用户登陆提示This account is currently not available
    Linux 切换用户提示Permission denied
    Netty核心组件之ChannelPipeline
    Netty核心组件之ChannelHandler
    Netty核心组件之Channel
    Netty核心组件之ChannlFuture
    Error creating bean with name 'eurekaAutoServiceRegistration'
    关于mysql数据库时间与java后台时间类型
    rabbitMQ-helloWorld
  • 原文地址:https://www.cnblogs.com/itdef/p/14633901.html
Copyright © 2011-2022 走看看