L2-2 小字辈
思路
bfs搜一下。
代码
#include <bits/stdc++.h>
using namespace std;
const int maxn=1e5+10;
vector<int> g[maxn];
int deep[maxn],vis[maxn];
int bfs(int s) {
int res=-1;
deep[s]=1;
queue<int> q;
q.push(s);
vis[s]=1;
while (!q.empty()) {
int f=q.front();
res=max(res,deep[f]);
q.pop();
for (auto next:g[f]) {
if (!vis[next]) {
deep[next]=deep[f]+1;
vis[next]=1;
q.push(next);
}
}
}
return res;
}
int main()
{
int n,fa,s;
scanf("%d",&n);
for (int i=1;i<=n;i++) {
scanf("%d",&fa);
if (fa!=-1) {
g[fa].push_back(i);
}
else {
s=i;
}
}
int maxdp=bfs(s);
int print=0;
printf("%d\n",maxdp);
for (int i=1;i<=n;i++) {
if (deep[i]==maxdp) {
if (!print) {
print=1;
}
else {
printf(" ");
}
printf("%d",i);
}
}
printf("\n");
return 0;
}