码迷,mamicode.com
首页 > 其他好文 > 详细

L2-2 小字辈

时间:2020-02-20 21:58:22      阅读:70      评论:0      收藏:0      [点我收藏+]

标签:its   next   names   main   space   return   vector   std   ons   

思路

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;
}

L2-2 小字辈

标签:its   next   names   main   space   return   vector   std   ons   

原文地址:https://www.cnblogs.com/xyqxyq/p/12337454.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!