#include <bits/stdc++.h>
using namespace std;
void dfs(int a, int dis, const vector<vector<int>> &g, vector<int> &dist) {
dist[a] = dis;
for(auto i : g[a]) {
dfs(i, dis+1, g,dist);
}
}
int main() {
int n; cin >> n;
vector<int> x(n+1);
vector<vector<int>> g(n+1);
vector<int> indeg(n+1);
vector<bool> kor(n+1, true);
vector<int> dist(n+1, 0);
for(int i = 1; i <= n; i++) {
int a; cin >> a;
x[i] = a;
g[a].push_back(i);
indeg[a]++;
}
queue<int> q;
for(int i = 1; i <= n; i++) {
if(indeg[i] == 0) q.push(i);
}
while(q.size() != 0) {
int w = q.front();
q.pop();
kor[w] = false;
indeg[x[w]]--;
if(indeg[x[w]] == 0) q.push(x[w]);
}
for(int i = 1; i <= n; i++) {
if(kor[i] == true && dist[i] == 0) {
int dis = 1;
int z = x[i];
while(z != i) {
dis++;
z = x[z];
}
dist[i] = dis;
z = x[i];
while(z != i) {
dist[z] = dis;
z = x[z];
}
}
}
for(int i = 1; i <= n; i++) {
if(kor[i] == true) {
for(auto j : g[i]) {
if(kor[j] == false) {
dfs(j, dist[i]+1,g,dist);
}
}
}
}
int ans = 0;
int ln = 0;
for(int i = 1; i <= n; i++) {
if(dist[i] > ln) {
ln = dist[i];
ans = i;
}
}
cout << ans << " " << dist[ans];
}
| Részfeladat | Összpont | Teszt | Verdikt | Idő | Memória | ||
|---|---|---|---|---|---|---|---|
| subtask1 | 0/0 | ||||||
| 1 | Elfogadva | 1ms | 500 KiB | ||||
| subtask2 | 20/20 | ||||||
| 2 | Elfogadva | 2ms | 500 KiB | ||||
| 3 | Elfogadva | 2ms | 508 KiB | ||||
| 4 | Elfogadva | 2ms | 316 KiB | ||||
| 5 | Elfogadva | 2ms | 316 KiB | ||||
| 6 | Elfogadva | 2ms | 316 KiB | ||||
| 7 | Elfogadva | 2ms | 316 KiB | ||||
| 8 | Elfogadva | 2ms | 544 KiB | ||||
| 9 | Elfogadva | 2ms | 316 KiB | ||||
| 10 | Elfogadva | 2ms | 316 KiB | ||||
| 11 | Elfogadva | 2ms | 316 KiB | ||||
| 12 | Elfogadva | 2ms | 316 KiB | ||||
| subtask3 | 18/18 | ||||||
| 13 | Elfogadva | 150ms | 13620 KiB | ||||
| 14 | Elfogadva | 149ms | 13620 KiB | ||||
| 15 | Elfogadva | 149ms | 13732 KiB | ||||
| 16 | Elfogadva | 118ms | 13616 KiB | ||||
| 17 | Elfogadva | 144ms | 13620 KiB | ||||
| 18 | Elfogadva | 126ms | 13624 KiB | ||||
| 19 | Elfogadva | 140ms | 13620 KiB | ||||
| 20 | Elfogadva | 125ms | 13556 KiB | ||||
| 21 | Elfogadva | 128ms | 13620 KiB | ||||
| 22 | Elfogadva | 115ms | 13656 KiB | ||||
| subtask4 | 42/42 | ||||||
| 23 | Elfogadva | 1ms | 316 KiB | ||||
| 24 | Elfogadva | 2ms | 500 KiB | ||||
| 25 | Elfogadva | 2ms | 508 KiB | ||||
| 26 | Elfogadva | 2ms | 316 KiB | ||||
| 27 | Elfogadva | 2ms | 316 KiB | ||||
| 28 | Elfogadva | 2ms | 316 KiB | ||||
| 29 | Elfogadva | 2ms | 316 KiB | ||||
| 30 | Elfogadva | 2ms | 544 KiB | ||||
| 31 | Elfogadva | 2ms | 316 KiB | ||||
| 32 | Elfogadva | 2ms | 316 KiB | ||||
| 33 | Elfogadva | 2ms | 316 KiB | ||||
| 34 | Elfogadva | 2ms | 316 KiB | ||||
| 35 | Elfogadva | 150ms | 13620 KiB | ||||
| 36 | Elfogadva | 149ms | 13620 KiB | ||||
| 37 | Elfogadva | 149ms | 13732 KiB | ||||
| 38 | Elfogadva | 118ms | 13616 KiB | ||||
| 39 | Elfogadva | 144ms | 13620 KiB | ||||
| 40 | Elfogadva | 126ms | 13624 KiB | ||||
| 41 | Elfogadva | 140ms | 13620 KiB | ||||
| 42 | Elfogadva | 125ms | 13556 KiB | ||||
| 43 | Elfogadva | 128ms | 13620 KiB | ||||
| 44 | Elfogadva | 115ms | 13656 KiB | ||||
| 45 | Elfogadva | 146ms | 11820 KiB | ||||
| 46 | Elfogadva | 135ms | 11572 KiB | ||||
| 47 | Elfogadva | 136ms | 11576 KiB | ||||
| 48 | Elfogadva | 152ms | 11672 KiB | ||||
| 49 | Elfogadva | 152ms | 11572 KiB | ||||
| 50 | Elfogadva | 156ms | 11572 KiB | ||||
| 51 | Elfogadva | 136ms | 12148 KiB | ||||
| 52 | Elfogadva | 134ms | 12188 KiB | ||||
| 53 | Elfogadva | 130ms | 11572 KiB | ||||
| 54 | Elfogadva | 122ms | 11584 KiB | ||||