L2 026 小字輩 vector 模擬

2021-08-18 12:48:54 字數 1508 閱讀 5959

時間限制

400 ms

記憶體限制

65536 kb

**長度限制

8000 b

判題程式

standard 作者

陳越本題給定乙個龐大家族的家譜,要請你給出最小一輩的名單。

輸入格式:

輸入在第一行給出家族人口總數 n(不超過 100 000 的正整數) —— 簡單起見,我們把家族成員從 1 到 n 編號。隨後第二行給出 n 個編號,其中第 i 個編號對應第 i 位成員的父/母。家譜中輩分最高的老祖宗對應的父/母編號為 -1。一行中的數字間以空格分隔。

輸出格式:

首先輸出最小的輩分(老祖宗的輩分為 1,以下逐級遞增)。然後在第二行按遞增順序輸出輩分最小的成員的編號。編號間以乙個空格分隔,行首尾不得有多餘空格。

輸入樣例:

9

2 6 5 5 -1 5 6 4 7

輸出樣例:
4

1 9

考試當天也就一遍ac了,後來重寫了一遍居然花了乙個多小時(考場效率,果然deadline是第一生產線

這題我用的方法是建立乙個「樹狀關係」

建立起父子關係 子們用vector去儲存 讀取的時候使用c風格的下標讀取 

通過結構體陣列等各種關係去鏈結 建立關係

#include#includeusing namespace std;

const int maxn=100000+5;

int arr[maxn]=;

int n;

struct rela;

//分別用於儲存

rela pel[maxn];

int mmaxn=1;

void init()

}void bfs(int mem)

for(vector::size_type i=0;i>n;

for(int i=1;i<=n;i++)

cin>>arr[i];

int mem=0;

for(int i=1;i<=n;i++)

else

} bfs(mem);

//for(int i=1;i<=n;i++);

int n;

struct rela;

rela pel[maxn];

int mmaxn=0;

void init()

}void bfs(int mem)

for(int i=0;i>n;

for(int i=1;i<=n;i++)

cin>>arr[i];

int mem=0;

for(int i=1;i<=n;i++)

else

} pel[mem].level=1;

bfs(mem);

//for(int i=1;i<=n;i++){

// cout《盡量避免這種寫法,使用stl最為簡潔和安全。

L2 026 小字輩,遞迴

本題給定乙個龐大家族的家譜,要請你給出最小一輩的名單。輸入格式 輸入在第一行給出家族人口總數 n 不超過 100 000 的正整數 簡單起見,我們把家族成員從 1 到 n 編號。隨後第二行給出 n 個編號,其中第 i 個編號對應第 i 位成員的父 母。家譜中輩分最高的老祖宗對應的父 母編號為 1。一...

L2 026 小字輩(25 分)

本題給定乙個龐大家族的家譜,要請你給出最小一輩的名單。輸入格式 輸入在第一行給出家族人口總數 n 不超過 100 000 的正整數 簡單起見,我們把家族成員從 1 到 n 編號。隨後第二行給出 n 個編號,其中第i 個編號對應第 i 位成員的父 母。家譜中輩分最高的老祖宗對應的父 母編號為 1。一行...

L2 026 小字輩(25 分)

l2 026 小字輩 25 分 本題給定乙個龐大家族的家譜,要請你給出最小一輩的名單。輸入格式 輸入在第一行給出家族人口總數 n 不超過 100 000 的正整數 簡單起見,我們把家族成員從 1 到 n 編號。隨後第二行給出 n 個編號,其中第 i 個編號對應第 i 位成員的父 母。家譜中輩分最高的...