199022025-12-29 12:54:58LllamaHírlánccpp17Elfogadva 80/8083ms3756 KiB
#include <iostream>
#include<vector>
using namespace std;

vector<int> c;
vector<int> eler;
vector<int> volt;
int bejid = 1;


void bejar (int kezd) {
    int id = bejid++;
    vector<int> erintett;
    int u = kezd;

    while (true) {
        volt[u] = id;
        erintett.push_back(u);

        int kov = c[u];

        if (volt[kov] == id) {
            int hossz = 1;
            for (int i = (int)erintett.size() - 1; erintett[i] != kov; i--) hossz++;

            bool korben = false;
            for (int x : erintett) {
                if (x == kov) korben = true;
                if (korben) eler[x] = hossz;
            }

            for (int i = (int)erintett.size() - 1; i >= 0; i--) {
                int x = erintett[i];
                if (eler[x]) continue;
                eler[x] = eler[c[x]] + 1;
            }

            return;
        }


        if (eler[kov] > 0) {
            int val = eler[kov];
            for (int i = (int)erintett.size() - 1; i >= 0; i--) {
                eler[erintett[i]] = val + 1;
                val++;
            }
            return;
        }

        u = kov;
    }
}
int main()
{
    int n;
    cin >> n;

    c.assign(n + 1, 0);
    eler.assign(n + 1, 0);
    volt.assign(n + 1, 0);

    for (int i = 1; i <= n; i++) cin >> c[i];
    
    for (int i = 1; i <= n; i++) {
        if (!eler[i]) bejar(i);
    }

    int best = 1;

    for (int i = 2; i <= n; i++) {
        //cout << eler[i] << ' ';
        if (eler[i] > eler[best]) best = i;
    }

    cout << best << ' ' << eler[best];
}
RészfeladatÖsszpontTesztVerdiktIdőMemória
subtask10/0
1Elfogadva1ms316 KiB
subtask220/20
2Elfogadva2ms316 KiB
3Elfogadva2ms316 KiB
4Elfogadva2ms500 KiB
5Elfogadva2ms316 KiB
6Elfogadva2ms316 KiB
7Elfogadva2ms376 KiB
8Elfogadva1ms316 KiB
9Elfogadva1ms316 KiB
10Elfogadva2ms500 KiB
11Elfogadva2ms316 KiB
12Elfogadva2ms392 KiB
subtask318/18
13Elfogadva79ms2612 KiB
14Elfogadva76ms2768 KiB
15Elfogadva76ms2836 KiB
16Elfogadva76ms2768 KiB
17Elfogadva78ms3080 KiB
18Elfogadva78ms3512 KiB
19Elfogadva79ms3376 KiB
20Elfogadva79ms3504 KiB
21Elfogadva79ms3756 KiB
22Elfogadva79ms3756 KiB
subtask442/42
23Elfogadva1ms316 KiB
24Elfogadva2ms316 KiB
25Elfogadva2ms316 KiB
26Elfogadva2ms500 KiB
27Elfogadva2ms316 KiB
28Elfogadva2ms316 KiB
29Elfogadva2ms376 KiB
30Elfogadva1ms316 KiB
31Elfogadva1ms316 KiB
32Elfogadva2ms500 KiB
33Elfogadva2ms316 KiB
34Elfogadva2ms392 KiB
35Elfogadva79ms2612 KiB
36Elfogadva76ms2768 KiB
37Elfogadva76ms2836 KiB
38Elfogadva76ms2768 KiB
39Elfogadva78ms3080 KiB
40Elfogadva78ms3512 KiB
41Elfogadva79ms3376 KiB
42Elfogadva79ms3504 KiB
43Elfogadva79ms3756 KiB
44Elfogadva79ms3756 KiB
45Elfogadva83ms2612 KiB
46Elfogadva82ms2612 KiB
47Elfogadva82ms2544 KiB
48Elfogadva82ms2760 KiB
49Elfogadva82ms2792 KiB
50Elfogadva82ms2868 KiB
51Elfogadva82ms2868 KiB
52Elfogadva82ms2868 KiB
53Elfogadva82ms3048 KiB
54Elfogadva83ms3416 KiB