蓝桥备战-区间嵌套--前缀和做法

简介: 蓝桥备战-区间嵌套--前缀和做法

题目:

思路:

区间按照左端点排序,如果左端点相等,则按照右端点逆序排序(右端点越大越好),从前往后一次枚举每个区间,如果一个区间后面存在一个区间的右端点小于等于我这个区间的右端点那么即存在。所以我们只需要看后面是否存在一个最小的右端点是否小于等于该区间的右端点即可。

创建一个后缀和维护区间右端点最小值。

代码:

#include <iostream>
#include <algorithm>
using namespace std;
typedef pair<int,int> PII;
const int N = 3e5 +10;
int n;
struct Range
{
    int x, y, id;
    bool operator < (const Range &r)
    {
        if (x != r.x)   return x < r.x;
        else return r.y < y;
    }
}range[N];
Range b[N];
int main()
{
    cin >> n;
    for (int i = 0; i < N; i++)
        b[i].y = 0x3f3f3f3f;
    for (int i = 0; i < n; i++)
    {
        int a, b;
        cin >> a >> b;
        range[i] = {a, b, i};
    }
    sort (range, range + n);
    for (int i = n - 1; i >= 0; i--)
    {
        b[i] = b[i + 1];
        if (b[i].y >= range[i].y)
            b[i] = range[i];
    }
    for (int i = 0; i < n; i++)
    {
        if (range[i].y >= b[i + 1].y)
        {
            cout << b[i + 1].id + 1 << " ";
            cout << range[i].id + 1;
            return 0;
        }
    }
    cout << "-1 -1";
    return 0;
}

另一种比较巧妙的思路:

我们只需要枚举相邻区间即可,因为如果枚举相邻区间的时候没有出现右端点逆序的(可等于),便代表所有区间的右端点是升序的(不包含等于)。那么及不存在嵌套区间。所以想要出现嵌套区间相邻区间必然存在右端点逆序。

代码:

#include <iostream>
#include <algorithm>
using namespace std;
const int N = 3e5 +10;
int n;
struct Range
{
    int x, y, id;
    bool operator < (const Range &r)
    {
        if (x != r.x)   return x < r.x;
        else return r.y < y;
    }
}range[N];
int main()
{
    cin >> n;
    for (int i = 0; i < n; i++)
    {
        int a, b;
        cin >> a >> b;
        range[i] = {a, b, i};
    }
    sort (range, range + n);
    for (int i = 0; i < n - 1; i++)
    {
        if (range[i].y >= range[i + 1].y)
        {
            cout << range[i + 1].id + 1 << " ";
            cout << range[i].id + 1;
            return 0;
        }
    }
    cout << "-1 -1";
    return 0;
}


目录
相关文章
|
2月前
|
机器学习/深度学习 算法 搜索推荐
第四十五练 请以递归方式实现斐波那契数列的第 n 项
第四十五练 请以递归方式实现斐波那契数列的第 n 项
25 1
|
5月前
|
人工智能 算法
代码随想录算法训练营第三十五天 | LeetCode 435. 无重叠区间、763. 划分字母区间、56. 合并区间
代码随想录算法训练营第三十五天 | LeetCode 435. 无重叠区间、763. 划分字母区间、56. 合并区间
41 0
|
5月前
|
算法 索引
代码随想录算法训练营第二天 |977.有序数组平方,209.长度最小的字数组,59.螺旋矩阵
代码随想录算法训练营第二天 |977.有序数组平方,209.长度最小的字数组,59.螺旋矩阵
|
5月前
|
算法 网络架构
代码随想录算法训练营第三十三天 | LeetCode 1005. K 次取反后最大化的数组和、134. 加油站、135. 分发糖果
代码随想录算法训练营第三十三天 | LeetCode 1005. K 次取反后最大化的数组和、134. 加油站、135. 分发糖果
32 0
|
10月前
|
机器学习/深度学习 监控 算法
代码随想录训练营day36| 738.单调递增的数字 968.监控二叉树
代码随想录训练营day36| 738.单调递增的数字 968.监控二叉树
106 1
|
10月前
|
机器学习/深度学习 监控 算法
代码随想录训练营day37| 738.单调递增的数字 968.监控二叉树
代码随想录训练营day37| 738.单调递增的数字 968.监控二叉树
|
10月前
|
算法 索引
代码随想录训练营day34| 1005.K次取反后最大化的数组和 134. 加油站 135. 分发糖果...
代码随想录训练营day34| 1005.K次取反后最大化的数组和 134. 加油站 135. 分发糖果...
随机练习题:浅浅固定思路
随机练习题:浅浅固定思路
248 0
|
算法 Java C++
代码随想录刷题|LeetCode 1005.K次取反后最大化的数组和 134. 加油站 135. 分发糖果
代码随想录刷题|LeetCode 1005.K次取反后最大化的数组和 134. 加油站 135. 分发糖果