180592025-09-25 18:46:59algoproTestnevelés óracpp17Accepted 50/50125ms14120 KiB
// UUID: 07d1ac42-a158-4ea2-b380-1316a160808a
#include <bits/stdc++.h>
#include <queue>
using namespace std;

int main() {
    ios::sync_with_stdio(false);
    cin.tie(0);
    int n, m;cin >> n >> m;
    vector<vector<int>> g(n+1);
    vector<int> c(n+1, 0);
    for(int i = 0; i < m; i++)
    {
        int a,b;cin >> a >> b;
        c[b]++;
        g[a].push_back(b);
    }
    queue<int> q;
    vector<int> ans;
    for(int i = 1; i <= n; i++) if(c[i] == 0) q.push(i); 
    while(!q.empty())
    {
        int v = q.front();
        ans.push_back(v);
        q.pop();
       
        for(int e: g[v])
        {
            c[e]--;
            if(c[e] == 0) q.push(e);
        }
    }
    if(ans.size() < n)
    {
        cout << "0";
        return 0;
    }
    vector<int>ans2 = ans;
    for(int i = 0; i < n-1; i++)
    {
        int a = ans[i];int b = ans[i+1];
        bool connected = false;
        for(int e: g[a])
        {
            if(e == b) connected = true;
        }
        if(!connected)
        {
            swap(ans2[i], ans2[i+1]);
            cout << "2\n";
            for(int v: ans) cout << v << " ";
            cout << "\n";
            for(int v: ans2) cout << v << " ";
            return 0;
        }         
    }
    cout << "1\n";
    for(int a: ans) cout << a << " ";
}

/*


beolvasasás
befokok számolása

sor létrehozása
források a sorba

queue <int> q;
vector <int> ans;

while (q.size()>0){
    
    int x = q.front();
    q.pop();

    for (int y : g[x]) {
        y befokát csökkentem
        ha 0-ra csökkent, akkor beteszem a sorba
    }

}

ans mérete alapján eldöntöm

----------------------------------------

Létezik-e több?


*/
SubtaskSumTestVerdictTimeMemory
base50/50
1Accepted0/01ms316 KiB
2Accepted0/01ms508 KiB
3Accepted0/097ms7600 KiB
4Accepted2/21ms316 KiB
5Accepted3/31ms316 KiB
6Accepted3/31ms508 KiB
7Accepted3/31ms352 KiB
8Accepted1/11ms356 KiB
9Accepted3/31ms316 KiB
10Accepted3/32ms316 KiB
11Accepted3/32ms316 KiB
12Accepted1/12ms316 KiB
13Accepted2/22ms508 KiB
14Accepted3/31ms316 KiB
15Accepted1/176ms4592 KiB
16Accepted3/386ms10336 KiB
17Accepted5/543ms10940 KiB
18Accepted1/1116ms14120 KiB
19Accepted2/274ms4784 KiB
20Accepted3/3125ms12240 KiB
21Accepted4/4112ms12204 KiB
22Accepted4/4101ms12200 KiB