// hirlanc.cpp : This file contains the 'main' function. Program execution begins and ends there.
//
#include <iostream>
#include <vector>
using namespace std;
struct adat {
int be, sz;
bool lat;
};
vector<adat>x;
vector<int>csp;
pair<int, int>sol;
int n, hossz;
void bejar(int akt)
{
x[akt].lat = true;
++hossz;
if (x[x[akt].sz].lat == false)
{
bejar(x[akt].sz);
}
x[akt].lat = false;
return;
}
void kor(int akt, int kezd)
{
x[akt].lat = true;
++hossz;
if (x[x[akt].sz].lat == false)
{
kor(x[akt].sz, kezd);
}
}
int main()
{
cin >> n;
x.resize(n + 1, { 0,0,0 });
int a = 0;
for (int i = 1; i <= n; ++i)
{
cin >> a;
x[i].sz = a;
x[a].be = i;
}
for (int i = 1; i <= n; ++i)
{
if (x[i].be == 0)
{
csp.push_back(i);
}
}
sol.first = 0;
sol.second = 0;
if (!csp.empty())
{
for (auto& e : csp)
{
bejar(e);
if (hossz > sol.second)
{
sol.first = e;
sol.second = hossz;
}
hossz = 0;
}
}
else
{
for (int i = 1; i <= n; ++i)
{
if (x[i].lat == false)
{
kor(i, i);
if (hossz > sol.second)
{
sol.first = i;
sol.second = hossz;
}
}
}
}
cout << sol.first << " " << sol.second;
}
// Run program: Ctrl + F5 or Debug > Start Without Debugging menu
// Debug program: F5 or Debug > Start Debugging menu
// Tips for Getting Started:
// 1. Use the Solution Explorer window to add/manage files
// 2. Use the Team Explorer window to connect to source control
// 3. Use the Output window to see build output and other messages
// 4. Use the Error List window to view errors
// 5. Go to Project > Add New Item to create new code files, or Project > Add Existing Item to add existing code files to the project
// 6. In the future, to open this project again, go to File > Open > Project and select the .sln file
| Részfeladat | Összpont | Teszt | Verdikt | Idő | Memória | ||
|---|---|---|---|---|---|---|---|
| subtask1 | 0/0 | ||||||
| 1 | Elfogadva | 1ms | 316 KiB | ||||
| subtask2 | 0/20 | ||||||
| 2 | Elfogadva | 1ms | 508 KiB | ||||
| 3 | Elfogadva | 2ms | 548 KiB | ||||
| 4 | Elfogadva | 2ms | 316 KiB | ||||
| 5 | Elfogadva | 3ms | 316 KiB | ||||
| 6 | Elfogadva | 3ms | 316 KiB | ||||
| 7 | Elfogadva | 3ms | 316 KiB | ||||
| 8 | Elfogadva | 4ms | 316 KiB | ||||
| 9 | Elfogadva | 7ms | 316 KiB | ||||
| 10 | Hibás válasz | 1ms | 316 KiB | ||||
| 11 | Hibás válasz | 1ms | 316 KiB | ||||
| 12 | Hibás válasz | 1ms | 316 KiB | ||||
| subtask3 | 0/18 | ||||||
| 13 | Hibás válasz | 81ms | 2752 KiB | ||||
| 14 | Hibás válasz | 79ms | 2580 KiB | ||||
| 15 | Hibás válasz | 78ms | 2760 KiB | ||||
| 16 | Hibás válasz | 79ms | 2756 KiB | ||||
| 17 | Hibás válasz | 79ms | 2612 KiB | ||||
| 18 | Hibás válasz | 78ms | 2612 KiB | ||||
| 19 | Hibás válasz | 78ms | 2612 KiB | ||||
| 20 | Hibás válasz | 79ms | 2796 KiB | ||||
| 21 | Hibás válasz | 78ms | 2864 KiB | ||||
| 22 | Elfogadva | 78ms | 2804 KiB | ||||
| subtask4 | 0/42 | ||||||
| 23 | Elfogadva | 1ms | 508 KiB | ||||
| 24 | Elfogadva | 1ms | 508 KiB | ||||
| 25 | Elfogadva | 2ms | 548 KiB | ||||
| 26 | Elfogadva | 2ms | 316 KiB | ||||
| 27 | Elfogadva | 3ms | 316 KiB | ||||
| 28 | Elfogadva | 3ms | 316 KiB | ||||
| 29 | Elfogadva | 3ms | 316 KiB | ||||
| 30 | Elfogadva | 4ms | 316 KiB | ||||
| 31 | Elfogadva | 7ms | 316 KiB | ||||
| 32 | Hibás válasz | 1ms | 316 KiB | ||||
| 33 | Hibás válasz | 1ms | 316 KiB | ||||
| 34 | Hibás válasz | 1ms | 316 KiB | ||||
| 35 | Hibás válasz | 81ms | 2752 KiB | ||||
| 36 | Hibás válasz | 79ms | 2580 KiB | ||||
| 37 | Hibás válasz | 78ms | 2760 KiB | ||||
| 38 | Hibás válasz | 79ms | 2756 KiB | ||||
| 39 | Hibás válasz | 79ms | 2612 KiB | ||||
| 40 | Hibás válasz | 78ms | 2612 KiB | ||||
| 41 | Hibás válasz | 78ms | 2612 KiB | ||||
| 42 | Hibás válasz | 79ms | 2796 KiB | ||||
| 43 | Hibás válasz | 78ms | 2864 KiB | ||||
| 44 | Elfogadva | 78ms | 2804 KiB | ||||
| 45 | Elfogadva | 103ms | 3244 KiB | ||||
| 46 | Elfogadva | 381ms | 3396 KiB | ||||
| 47 | Időlimit túllépés | 584ms | 3392 KiB | ||||
| 48 | Időlimit túllépés | 600ms | 3404 KiB | ||||
| 49 | Időlimit túllépés | 582ms | 3248 KiB | ||||
| 50 | Időlimit túllépés | 583ms | 3512 KiB | ||||
| 51 | Időlimit túllépés | 579ms | 3504 KiB | ||||
| 52 | Időlimit túllépés | 600ms | 3504 KiB | ||||
| 53 | Időlimit túllépés | 586ms | 3908 KiB | ||||
| 54 | Időlimit túllépés | 577ms | 4016 KiB | ||||