传送门:QAQ
题意:给你n个区间,问你删掉一个区间,最大的区间交。
思路:区间交肯定是最小的右区间减去最大的左区间(或者不存在)
multiset 可以记录重复还能排序。扔进去枚举一下就行了。
代码:
#include<cstdio>
#include<cstring>
#include<cstdlib>
#include<stack>
#include<vector>
#include<queue>
#include<set>
#include<map>
#include<algorithm>
using namespace std;
const int INF = 0x3f3f3f3f;
#define LL long long int
int l[300010];
int r[300010];
multiset<int>a, b;
int main(void) {
int n;
scanf("%d", &n);
for (int i = 0; i < n; i++) {
scanf("%d", &l[i]);
scanf("%d", &r[i]);
a.insert(l[i]);
b.insert(r[i]);
}
int ans = 0;
for (int i = 0; i < n; i++) {
a.erase(a.find(l[i]));
b.erase(b.find(r[i]));
ans = max(ans, *b.begin() - *a.rbegin());
a.insert(l[i]);
b.insert(r[i]);
}
printf("%d\n", ans);
}