82742024-01-14 08:19:44MagyarKendeSZLGHőségriadó (50 pont)cpp17Hibás válasz 48/5028ms5676 KiB
#include <bits/stdc++.h>
#define speed cin.tie(0); ios::sync_with_stdio(0)
using namespace std;

int N;

vector<int> ranges(const vector<int>& tempS, int K, bool mn) {
    vector<int> v(N - K + 1);
    deque<int> q;

    for (int i = 0; i < N; i++) {
        while (!q.empty() && i - q.front() >= K) q.pop_front();
        while (!q.empty() && (
            mn ? tempS[q.back()] >= tempS[i] : 
            tempS[q.back()] <= tempS[i]
        )) q.pop_back();
        
        q.push_back(i);

        if (i >= K - 1) {
            v[i - K + 1] = tempS[q.front()];
        }
    }
    
    return v;
}

int main() {
    int K, L, F;
    cin >> N >> K >> L >> F;

    vector<int> tempS(N);
    for (int& x : tempS) cin >> x;

    if (N < K || N < L) {
        cout << 0;
        exit(0);
    }

    vector<int> maxS = ranges(tempS, L, 0), minS = ranges(tempS, K, 1);

    int result = 0;
    bool alert = 0;
    for (int i = 0; i < N - K + 1 && i < N - L + 1; i++) {
        if (!alert && minS[i] > F) {
            alert = 1;
            i += K - 1;
            result++;
        }
        else if (maxS[i] < F) {
            alert = 0;
            i += L - 1;
        }
    }

    cout << result;
}
RészfeladatÖsszpontTesztVerdiktIdőMemória
base48/50
1Elfogadva0/03ms1812 KiB
2Elfogadva0/028ms4268 KiB
3Elfogadva2/23ms2336 KiB
4Hibás válasz0/23ms2460 KiB
5Elfogadva2/23ms2516 KiB
6Elfogadva2/22ms2512 KiB
7Elfogadva2/23ms2672 KiB
8Elfogadva4/43ms2688 KiB
9Elfogadva4/412ms3368 KiB
10Elfogadva4/414ms3544 KiB
11Elfogadva4/417ms4024 KiB
12Elfogadva4/414ms3860 KiB
13Elfogadva4/421ms4944 KiB
14Elfogadva4/44ms3492 KiB
15Elfogadva4/426ms5492 KiB
16Elfogadva4/426ms5452 KiB
17Elfogadva4/427ms5676 KiB