71982024-01-03 12:42:53horvathabelRendezéscpp17Accepted 40/40105ms5616 KiB
#include <bits/stdc++.h>
using namespace std;

int main()
{
    int n;
    cin>>n;
    int k;
    cin>>k;
    vector<int> pre;
    vector<int> v;
    pre.resize(n+1,0);
    for (int i=0; i<n;i++){
        int x;
        cin>>x;
        v.push_back(x);
    }
    for (int i=0; i<k;i++){
        int a,b;
        cin>>a>>b;
        a--;
        b--;
        pre[a]++;
        pre[b]--;
    }
    int ke=-1;
    int most=0;
    for (int i=0; i<n;i++){
        most+=pre[i];
        if (ke==-1 && most>0){
            ke=i;
        }
        if (most==0 && ke!=-1){
            sort(v.begin()+ke, v.begin()+i+1);
            ke=-1;
        }
    }
    int ans=0;
    for (int i=0; i<n;i++){
        if (v[i]==i+1) ans++;
    }
    cout<<ans<<endl;
}
SubtaskSumTestVerdictTimeMemory
base40/40
1Accepted0/03ms1808 KiB
2Accepted0/014ms2256 KiB
3Accepted2/23ms2216 KiB
4Accepted2/23ms2432 KiB
5Accepted2/23ms2640 KiB
6Accepted2/23ms2724 KiB
7Accepted2/23ms2976 KiB
8Accepted2/23ms2952 KiB
9Accepted2/23ms3044 KiB
10Accepted2/23ms2948 KiB
11Accepted2/298ms4936 KiB
12Accepted2/298ms4952 KiB
13Accepted2/2100ms5092 KiB
14Accepted1/1100ms5048 KiB
15Accepted2/2100ms5328 KiB
16Accepted2/2101ms5392 KiB
17Accepted2/2104ms5352 KiB
18Accepted2/2105ms5392 KiB
19Accepted2/2103ms5484 KiB
20Accepted1/1103ms5616 KiB
21Accepted2/2103ms5604 KiB
22Accepted2/2103ms5460 KiB
23Accepted2/2103ms5440 KiB