165992025-05-06 20:28:22algoproTornyokcpp17Futási hiba 82/100449ms160000 KiB
// UUID: cbbf7dc6-49f4-4c02-882a-56be44486106
#pragma GCC optimize("O3,no-stack-protector")
#include <bits/stdc++.h>
using namespace std;

const int MAXN = 1000005;
const int MAXK = 100005;

int n, k;

// Épületmagasságok és tornyok magassága
int h[MAXN];          // 0-tól n-1-ig, h[n] lesz INT_MAX
int towerH[MAXK];     // K darab toronymagasság
int numLess[MAXN];    // DP tömb
long long sortedArr[MAXN + MAXK]; // magasság és index együtt

// Szomszédsági lista: minden épülethez max N szomszédot tárolunk külön tömbben
int* nbrs[MAXN];      // minden elem egy külön dinamikus tömb
int nbrSize[MAXN];    // hány elem van egy adott lista esetén

// max méret minden listához – legrosszabb esetben n darab szomszéd is lehet
const int MAX_NEIGHBORS = 20;

int calcLess(int Indx) {
    if (numLess[Indx] >= 0) return numLess[Indx];
    int ans = 0;
    for (int i = 0; i < nbrSize[Indx]; i++) {
        ans = max(ans, calcLess(nbrs[Indx][i]) + 1);
    }
    return numLess[Indx] = ans;
}

int main() {
    ios_base::sync_with_stdio(false);
    cin.tie(NULL);

    cin >> n >> k;

    for (int i = 0; i < n; i++) {
        cin >> h[i];
        sortedArr[i] = (((long long)h[i]) << 32) | i;
    }

    for (int i = 0; i < k; i++) {
        cin >> towerH[i];
        sortedArr[n + i] = (((long long)towerH[i]) << 32) | (n + i);
    }

    h[n] = INT_MAX; // sentinel az utolsó helyen

    sort(sortedArr, sortedArr + n + k);

    // Inicializáljuk a szomszédlistákat
    for (int i = 0; i <= n; i++) {
        nbrs[i] = new int[MAX_NEIGHBORS];
        nbrSize[i] = 0;
    }

    stack<int> stc;
    stc.push(n);

    for (int i = 0; i < n; i++) {
        while (h[stc.top()] < h[i]) stc.pop();
        int top = stc.top();
        nbrs[top][nbrSize[top]++] = i;
        stc.push(i);
    }

    for (int i = 0; i <= n; i++) numLess[i] = -1;

    calcLess(n);

    int bestSoFar = 0;

    for (int i = 0; i < n + k; i++) {
        int idx = sortedArr[i] & 0xffffffff;
        if (idx >= n) {
            towerH[idx - n] = bestSoFar + 1;
        } else {
            bestSoFar = max(bestSoFar, numLess[idx]);
        }
    }

    for (int i = 0; i < k; i++) {
        cout << towerH[i] << ' ';
    }
    cout << '\n';

    return 0;
}
RészfeladatÖsszpontTesztVerdiktIdőMemória
base82/100
1Elfogadva0/01ms500 KiB
2Elfogadva0/0321ms103476 KiB
3Elfogadva2/21ms316 KiB
4Elfogadva2/21ms568 KiB
5Elfogadva6/61ms572 KiB
6Elfogadva6/61ms576 KiB
7Elfogadva4/420ms7244 KiB
8Elfogadva4/429ms12752 KiB
9Futási hiba0/898ms47408 KiB
10Elfogadva8/8226ms88596 KiB
11Elfogadva5/5333ms102504 KiB
12Elfogadva5/5381ms121908 KiB
13Elfogadva5/570ms22580 KiB
14Elfogadva5/5159ms56832 KiB
15Elfogadva5/5199ms89140 KiB
16Elfogadva5/5287ms85036 KiB
17Elfogadva5/5349ms103476 KiB
18Elfogadva5/5381ms123188 KiB
19Elfogadva5/5389ms123064 KiB
20Időlimit túllépés0/5418ms157748 KiB
21Elfogadva5/5368ms158004 KiB
22Időlimit túllépés0/5449ms160000 KiB