区间有关问题

wuyoudexian / 2023-07-20 / 原文

求最大重叠区间

\(n\)个区间,求任意两个区间最大的重叠部分。

解法

首先把所有区间按左端点从小到大排序。设\(mx\)是前若干个区间的右端点最大能达到的值,对于每一个区间,设它的左端点为\(l\),右端点为\(r\),则其它区间与它的最大重叠部分为\(min(mx, r)-l\),遍历每个区间,维护答案。

总的时间复杂度为\(O(nlog_{}{n})\)

代码

#include<bits/stdc++.h>

using namespace std;
using ll = long long;

int main() {
    ios::sync_with_stdio(false);
    cin.tie(nullptr);
    
    int n;
    cin >> n;

    vector<pair<int, int>> s(n);
    for(int i = 0; i < n; i++) {
    	cin >> s[i].first >> s[i].second;
    }

    sort(s.begin(), s.end());

    int ans = 0, mx = s[0].second;
    for(int i = 1; i < n; i++) {
    	ans = max(ans, min(mx, s[i].second) - s[i].first);
    	mx = max(mx, s[i].second);
    }

    cout << ans << "\n";

    return 0;
}