小字辈
Posted xcfxcf
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了小字辈相关的知识,希望对你有一定的参考价值。
本题给定一个庞大家族的家谱,要请你给出最小一辈的名单。
输入格式:
输入在第一行给出家族人口总数 N(不超过 100 000 的正整数) —— 简单起见,我们把家族成员从 1 到 N 编号。随后第二行给出 N 个编号,其中第 i 个编号对应第 i 位成员的父/母。家谱中辈分最高的老祖宗对应的父/母编号为 -1。一行中的数字间以空格分隔。
输出格式:
首先输出最小的辈分(老祖宗的辈分为 1,以下逐级递增)。然后在第二行按递增顺序输出辈分最小的成员的编号。编号间以一个空格分隔,行首尾不得有多余空格。
输入样例:
9
2 6 5 5 -1 5 6 4 7
输出样例:
4
1 9
#include <bits/stdc++.h> using namespace std; const int maxn = 1e6 + 10; int n,ancestor; vector<int> ve[maxn]; int r[maxn],ans; void dfs(int x,int depth){ r[x] = depth; ans = max(ans,depth); for(int i = 0; i < ve[x].size(); i++){ r[ve[x][i]]++; dfs(ve[x][i],depth + 1); } } int main(){ //freopen("in","r",stdin); ios::sync_with_stdio(0); cin >> n; for(int i = 1; i <= n; i++){ int a;cin >> a; if(a == -1) ancestor = i; else ve[a].push_back(i); } dfs(ancestor,1); cout << ans << endl; int flag = 0; for(int i = 1; i <= n; i++){ if(r[i] == ans){ if(flag) cout << " " << i; else{ cout << i; flag ^= 1; } } } return 0; }
以上是关于小字辈的主要内容,如果未能解决你的问题,请参考以下文章