0
点赞
收藏
分享

微信扫一扫

Leetcode 1893. 检查是否区域内所有整数都被覆盖

小典典Rikako 2022-02-25 阅读 147

在这里插入图片描述
在这里插入图片描述
蛮搞笑的,运行多次居然效率变高了!!!!
给你一个二维整数数组 ranges 和两个整数 left 和 right 。每个 ranges[i] = [starti, endi] 表示一个从 starti 到 endi 的 闭区间 。

如果闭区间 [left, right] 内每个整数都被 ranges 中 至少一个 区间覆盖,那么请你返回 true ,否则返回 false 。

已知区间 ranges[i] = [starti, endi] ,如果整数 x 满足 starti <= x <= endi ,那么我们称整数x 被覆盖了。

示例 1:

输入:ranges = [[1,2],[3,4],[5,6]], left = 2, right = 5
输出:true
解释:25 的每个整数都被覆盖了:
- 2 被第一个区间覆盖。
- 34 被第二个区间覆盖。
- 5 被第三个区间覆盖。

示例 2:

输入:ranges = [[1,10],[10,20]], left = 21, right = 21
输出:false
解释:21 没有被任何一个区间覆盖。
 

提示:

  • 1 <= ranges.length <= 50
  • 1 <= starti <= endi <= 50
  • 1 <= left <= right <= 50

Code:

class Solution {
public:
    bool isCovered(vector<vector<int>>& ranges, int left, int right)
    {
        bool ret=false;
        
        sort(ranges.begin(),ranges.end());
        
        int count=0;
        
        for(int i=left;i<=right;i++)
        {
            for(int j=0;j<ranges.size();j++)
            {
                vector<int>vec=ranges[j];
                sort(vec.begin(),vec.end());
                if(vec[0]<=i&&vec[vec.size()-1]>=i)
                {
                    count++;
                    break;
                }
            }
        }
        cout<<count<<"====="<<(right-left)<<endl;
        return ((count)==(right-left+1));
        
    }
    
};
举报

相关推荐

0 条评论