9522022-02-04 20:38:41nmarciRendezéscpp11Elfogadva 40/40101ms25952 KiB
#include <iostream>
#include <vector>
#include <map>
#include <queue>
#include <string>
#include <set>
#include <algorithm>
#include <list>
using namespace std;
using ll = long long int;

ll inf = 1e9+7;

int main(){
    int n, m;
    cin >> n >> m;
    vector<int> v(n);
    for(auto& i : v){
        cin >> i;
    }
    vector<int> rend(n + 1,0);
    while(m--){
        int a, b;
        cin >>a >> b;
        --a, --b;
        ++rend[a]; --rend[b];
    }
    int i = 0, start = -1;
    int sum = 0;
    while(i < n){
        //cerr << rend[i] << " ";
        sum += rend[i];
        if(sum > 0 && start == -1){
            start = i;
        }
        if(sum == 0 && start != -1){
            sort(v.begin() + start, v.begin() + i + 1);
            //cerr << start << " " << i << endl;
            start = -1;
        }
        ++i;
    }
    //cerr << endl;
    int ans = 0;
    for(int i = 0; i < n; ++i){
        if(v[i] == i + 1) ++ans;
    }
    cout << ans << endl;
    return 0;
}
RészfeladatÖsszpontTesztVerdiktIdőMemória
base40/40
1Elfogadva0/02ms1736 KiB
2Elfogadva0/012ms2088 KiB
3Elfogadva2/21ms2052 KiB
4Elfogadva2/21ms2056 KiB
5Elfogadva2/21ms2056 KiB
6Elfogadva2/21ms2068 KiB
7Elfogadva2/22ms2076 KiB
8Elfogadva2/22ms2096 KiB
9Elfogadva2/22ms2104 KiB
10Elfogadva2/22ms2120 KiB
11Elfogadva2/290ms5248 KiB
12Elfogadva2/294ms7000 KiB
13Elfogadva2/296ms8628 KiB
14Elfogadva1/198ms10456 KiB
15Elfogadva2/2101ms12104 KiB
16Elfogadva2/285ms13832 KiB
17Elfogadva2/293ms15560 KiB
18Elfogadva2/290ms17292 KiB
19Elfogadva2/290ms19020 KiB
20Elfogadva1/190ms20756 KiB
21Elfogadva2/290ms22488 KiB
22Elfogadva2/289ms24220 KiB
23Elfogadva2/290ms25952 KiB