231392026-01-16 13:17:13AblablablaTitkos sorozatcpp17Elfogadva 40/4075ms10696 KiB
#include <bits/stdc++.h>

using namespace std;

int main(){
    int n;
    cin >> n;

    vector<int> alap(n);
    for(int &x : alap){
        cin >> x;
        x -= (x != -1);
    }

    int a = n;

    vector<int> ans(n);

    vector<vector<int>> csucsok(n, vector<int>());
    queue<int> bejar;
    vector<int> befok(n);
    for(int i = 0; i < n; i++){
        if(alap[i] == -1){

            ans[i] = a;
            a--;
            bejar.push(i);
        } else{
            for(int j = i + 1; j < alap[i]; j++){
                csucsok[i].push_back(j);
                befok[j]++;
            }

            csucsok[alap[i]].push_back(i);
            befok[i]++;
        }
    }

    vector<bool> bejart(n);

    while(!bejar.empty()){
        int akt = bejar.front();
        bejar.pop();

        if(bejart[akt]) continue;

        bejart[akt] = 1;

        for(int x : csucsok[akt]){
            if(bejart[x]) continue;

            befok[x]--;
            if(befok[x] == 0){
                bejar.push(x);
                ans[x] = a;
                a--;
            }
        }
    }


    for(int x : ans){
        cout << x << " ";
    }
    cout << "\n";
}
RészfeladatÖsszpontTesztVerdiktIdőMemória
base40/40
1Elfogadva0/01ms316 KiB
2Elfogadva0/032ms3892 KiB
3Elfogadva1/11ms316 KiB
4Elfogadva1/11ms316 KiB
5Elfogadva2/21ms316 KiB
6Elfogadva1/11ms316 KiB
7Elfogadva1/11ms316 KiB
8Elfogadva2/22ms464 KiB
9Elfogadva2/275ms10696 KiB
10Elfogadva2/274ms9256 KiB
11Elfogadva2/274ms9252 KiB
12Elfogadva2/267ms8248 KiB
13Elfogadva2/268ms7984 KiB
14Elfogadva2/265ms7728 KiB
15Elfogadva2/264ms7204 KiB
16Elfogadva3/364ms7216 KiB
17Elfogadva3/363ms7220 KiB
18Elfogadva3/364ms6964 KiB
19Elfogadva3/363ms6964 KiB
20Elfogadva3/357ms6964 KiB
21Elfogadva1/161ms7008 KiB
22Elfogadva1/159ms6868 KiB
23Elfogadva1/159ms6708 KiB