// UUID: 03cf9dac-c750-43a8-aa29-05b59e81aa3f
#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];
}
| Subtask | Sum | Test | Verdict | Time | Memory | ||
|---|---|---|---|---|---|---|---|
| subtask1 | 0/0 | ||||||
| 1 | Accepted | 1ms | 560 KiB | ||||
| subtask2 | 20/20 | ||||||
| 2 | Accepted | 2ms | 316 KiB | ||||
| 3 | Accepted | 2ms | 512 KiB | ||||
| 4 | Accepted | 2ms | 316 KiB | ||||
| 5 | Accepted | 2ms | 316 KiB | ||||
| 6 | Accepted | 2ms | 316 KiB | ||||
| 7 | Accepted | 2ms | 316 KiB | ||||
| 8 | Accepted | 2ms | 316 KiB | ||||
| 9 | Accepted | 2ms | 316 KiB | ||||
| 10 | Accepted | 2ms | 552 KiB | ||||
| 11 | Accepted | 2ms | 316 KiB | ||||
| 12 | Accepted | 2ms | 496 KiB | ||||
| subtask3 | 18/18 | ||||||
| 13 | Accepted | 125ms | 13712 KiB | ||||
| 14 | Accepted | 143ms | 13736 KiB | ||||
| 15 | Accepted | 126ms | 13560 KiB | ||||
| 16 | Accepted | 144ms | 13528 KiB | ||||
| 17 | Accepted | 125ms | 13696 KiB | ||||
| 18 | Accepted | 145ms | 13616 KiB | ||||
| 19 | Accepted | 141ms | 13632 KiB | ||||
| 20 | Accepted | 125ms | 13604 KiB | ||||
| 21 | Accepted | 122ms | 13508 KiB | ||||
| 22 | Accepted | 127ms | 13532 KiB | ||||
| subtask4 | 42/42 | ||||||
| 23 | Accepted | 1ms | 508 KiB | ||||
| 24 | Accepted | 2ms | 316 KiB | ||||
| 25 | Accepted | 2ms | 512 KiB | ||||
| 26 | Accepted | 2ms | 316 KiB | ||||
| 27 | Accepted | 2ms | 316 KiB | ||||
| 28 | Accepted | 2ms | 316 KiB | ||||
| 29 | Accepted | 2ms | 316 KiB | ||||
| 30 | Accepted | 2ms | 316 KiB | ||||
| 31 | Accepted | 2ms | 316 KiB | ||||
| 32 | Accepted | 2ms | 552 KiB | ||||
| 33 | Accepted | 2ms | 316 KiB | ||||
| 34 | Accepted | 2ms | 496 KiB | ||||
| 35 | Accepted | 125ms | 13712 KiB | ||||
| 36 | Accepted | 143ms | 13736 KiB | ||||
| 37 | Accepted | 126ms | 13560 KiB | ||||
| 38 | Accepted | 144ms | 13528 KiB | ||||
| 39 | Accepted | 125ms | 13696 KiB | ||||
| 40 | Accepted | 145ms | 13616 KiB | ||||
| 41 | Accepted | 141ms | 13632 KiB | ||||
| 42 | Accepted | 125ms | 13604 KiB | ||||
| 43 | Accepted | 122ms | 13508 KiB | ||||
| 44 | Accepted | 127ms | 13532 KiB | ||||
| 45 | Accepted | 152ms | 11820 KiB | ||||
| 46 | Accepted | 155ms | 11568 KiB | ||||
| 47 | Accepted | 133ms | 11572 KiB | ||||
| 48 | Accepted | 133ms | 11528 KiB | ||||
| 49 | Accepted | 152ms | 11572 KiB | ||||
| 50 | Accepted | 134ms | 11596 KiB | ||||
| 51 | Accepted | 135ms | 12084 KiB | ||||
| 52 | Accepted | 155ms | 12288 KiB | ||||
| 53 | Accepted | 131ms | 11744 KiB | ||||
| 54 | Accepted | 125ms | 11708 KiB | ||||