81492024-01-12 14:40:16ZsBalazsTitkos sorozatcpp17Hibás válasz 0/40347ms129704 KiB
#include <bits/stdc++.h>
using namespace std;

vector<vector<int>> graph;
vector<int> megoldas;
vector<int> mutat;
vector<bool> volt;

void bejar(int current) {
    if (volt[current]) return;
    
    volt[current] = true;
    
    for (int szom : graph[current]) {
        if (megoldas[szom] < megoldas[current]+1) {
            megoldas[szom] = megoldas[current]+1;
        }
        mutat[szom]--;
    }
}

int main() {
    int n;
    cin >> n;
    
    graph.resize(n);
    megoldas.assign(n, 0);
    mutat.assign(n, 0);
    volt.assign(n, false);
    
    for (int i = 0; n > i; i++) {
        int temp;
        cin >> temp;
        
        if (temp != -1) {
            temp--;
            
            mutat[temp]++;
            graph[i].push_back(temp);
            
            for (int j = i+1; temp > j; j++) {
                mutat[i]++;
                graph[j].push_back(i);
            }
        } else {
            for (int j = i+1; n > j; j++) {
                graph[j].push_back(i);
                mutat[i]++;
            }
        }
    }
    
    cout << 1 << endl;
    return 0;
    
    int counter = 0;
    while (counter < n) {
        for (int i = 0; n > i; i++) {
            if (mutat[i] == 0 && !volt[i]) {
                bejar(i);
                counter++;
            }
        }   
    }
    
    // megoldas, index
    vector<pair<int, int>> sor;
    
    for (int i = 0; n > i; i++) {
        sor.push_back({megoldas[i], i});
    }
    
    sort(sor.begin(), sor.end());
    
    vector<int> ans(n, 0);
    
    int next = 1;
    for (int i = 0; n > i; i++) {
        int index = sor[i].second;
        
        ans[index] = next;
        
        next++;
    }
    
    for (int a : ans) {
        cout << a << " ";
    }
    cout << endl;
    
	return 0;
}
RészfeladatÖsszpontTesztVerdiktIdőMemória
base0/40
1Hibás válasz0/03ms1912 KiB
2Hibás válasz0/028ms9096 KiB
3Hibás válasz0/13ms2576 KiB
4Hibás válasz0/13ms2688 KiB
5Hibás válasz0/23ms2900 KiB
6Hibás válasz0/13ms3068 KiB
7Hibás válasz0/13ms3300 KiB
8Hibás válasz0/24ms3888 KiB
9Hibás válasz0/275ms25688 KiB
10Hibás válasz0/2211ms120840 KiB
11Hibás válasz0/264ms21808 KiB
12Hibás válasz0/257ms21024 KiB
13Hibás válasz0/259ms21140 KiB
14Hibás válasz0/256ms21196 KiB
15Hibás válasz0/252ms21344 KiB
16Hibás válasz0/352ms21896 KiB
17Hibás válasz0/352ms22216 KiB
18Hibás válasz0/352ms22904 KiB
19Hibás válasz0/350ms23556 KiB
20Hibás válasz0/346ms23928 KiB
21Futási hiba0/1347ms129704 KiB
22Futási hiba0/1280ms129684 KiB
23Futási hiba0/1277ms129656 KiB