zoukankan      html  css  js  c++  java
  • [Leetcode Week2]Merge Intervals

    Merge Intervals题解

    原创文章,拒绝转载

    题目来源:https://leetcode.com/problems/merge-intervals/description/


    Description

    Given a collection of intervals, merge all overlapping intervals.

    Example

    Given [1,3],[2,6],[8,10],[15,18],
    return [1,6],[8,10],[15,18].
    

    Solution

    /* Definition for an interval.
     * struct Interval {
     *    int start;
     *    int end;
     *    Interval() : start(0), end(0) {}
     *    Interval(int s, int e) : start(s), end(e) {}
     * };
    */
     
    class Solution {
    public:
        vector<Interval> merge(vector<Interval>& intervals) {
            vector<Interval> resultVector;
            if (intervals.size() == 0)
                return resultVector;
    
            int size = intervals.size();
            int i, j, rsize;
    
            resultVector.push_back(intervals[0]);
    
            Interval tempInterval;
            bool is_finish;
    
            for (i = 1; i < size; i++) {
                tempInterval.start = intervals[i].start;
                tempInterval.end = intervals[i].end;
    
                is_finish = false;
                while (!is_finish) {
                    if (resultVector.size() == 0) {
                        resultVector.push_back(tempInterval);
                        break;
                    }
    
                    for (j = 0; j < resultVector.size(); j++) {
                        if ( (tempInterval.end >= resultVector[j].start && tempInterval.end <= resultVector[j].end) ||
                             (tempInterval.start >= resultVector[j].start && tempInterval.start <= resultVector[j].end) ||
                             (tempInterval.start <= resultVector[j].start && tempInterval.end >= resultVector[j].end)) {
    
                            tempInterval.start = tempInterval.start < resultVector[j].start ? tempInterval.start : resultVector[j].start;
                            tempInterval.end = tempInterval.end > resultVector[j].end ? tempInterval.end : resultVector[j].end;
                            resultVector.erase(resultVector.begin() + j);
                            break;
                        }
                        if (j == resultVector.size() - 1) {
                            resultVector.push_back(tempInterval);
                            is_finish = true;
                            break;
                        }
                    }
                }
            }        
    
            return resultVector;
        }
    };
    

    解题描述

    这道题还是费了一番周折去解决的。可能一开始的想法就是不想使用暴力破解的方法,想试着看看在解决问题的过程中就实现优化,减少遍历次数,但是却弄巧成拙出了些莫名奇妙的bug,一度WA好几次。最后还是妥协了,“先做到,再做好”,使用暴力破解,也就是通过不断更新即将插入结果容器的区间的上下界,每次更新完再重复遍历结果容器,以达到完全排除区间有交叠的情况。

  • 相关阅读:
    python 替换图片中的像素
    python paddleocr 增加识别速度的方法
    mysql 子查询少用
    mysql 临时表代替in的方法
    mysql创建临时表不用创建临时表结构的方法
    Nginx 报错 connect() failed (110: Connection timed out) while connecting to upstream
    用mkcert生成SSL,内网完美起跑https
    用于制作任何echarts地图(省、市、区、城镇街道)
    javascript执行机制
    ES6便捷语法
  • 原文地址:https://www.cnblogs.com/yanhewu/p/7525378.html
Copyright © 2011-2022 走看看