[PAT甲級(jí)]1004 Counting Leaves (30 分)

題目

1004 Counting Leaves (30 分)
A family hierarchy is usually presented by a pedigree tree. Your job is to count those family members who have no child.

Input Specification:
Each input file contains one test case. Each case starts with a line containing 0<N<100, the number of nodes in a tree, and M (<N), the number of non-leaf nodes. Then M lines follow, each in the format:

ID K ID[1] ID[2] ... ID[K]
where ID is a two-digit number representing a given non-leaf node, K is the number of its children, followed by a sequence of two-digit ID's of its children. For the sake of simplicity, let us fix the root ID to be 01.

The input ends with N being 0. That case must NOT be processed.

Output Specification:
For each test case, you are supposed to count those family members who have no child for every seniority level starting from the root. The numbers must be printed in a line, separated by a space, and there must be no extra space at the end of each line.

The sample case represents a tree with only 2 nodes, where 01 is the root and 02 is its only child. Hence on the root 01 level, there is 0 leaf node; and on the next level, there is 1 leaf node. Then we should output 0 1 in a line.

Sample Input:
2 1
01 1 02
Sample Output:
0 1

分析

這道題主要考察的是dfs的運(yùn)用篮幢,因?yàn)樵跇渲惺遣粫?huì)有回路的,所以dfs過(guò)程中不需要輔助數(shù)組vis,在dfs中需要考慮level也就是每一層樹中葉子節(jié)點(diǎn)的個(gè)數(shù),所以多加一個(gè)level參數(shù)。退出條件是遍歷到葉子結(jié)點(diǎn)(葉子節(jié)點(diǎn)沒(méi)有子樹了)宙暇,同時(shí)要存儲(chǔ)一個(gè)最大的level數(shù)儒洛,用于輸出level數(shù)組鞍恢。
解法中使用二維數(shù)組來(lái)存儲(chǔ)樹的結(jié)構(gòu)

代碼


#include<iostream>
#include<vector>
using namespace std;
#define maxn 101
vector<int>node[maxn];
int level[maxn]={0};
int maxlevel=0;

void dfs(int n,int l){
    if(node[n].size()==0){
        level[l]++;
        if(l>maxlevel)
            maxlevel=l;
        return;
    }
    for(int i=0;i<node[n].size();i++){
        dfs(node[n][i],l+1);
    }
}

int main(){
    int n,m;
    cin>>n>>m;
    for(int i=0;i<m;i++){
        int u,k;
        cin>>u>>k;
        for(int j=0;j<k;j++){
            int x;
            cin>>x;
            node[u].push_back(x);
        }
    }
    dfs(1,0);
    cout<<level[0];
    for(int i=1;i<=maxlevel;i++){
        cout<<" "<<level[i];
    }
}
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末房维,一起剝皮案震驚了整個(gè)濱河市沼瘫,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌握巢,老刑警劉巖晕鹊,帶你破解...
    沈念sama閱讀 219,039評(píng)論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異暴浦,居然都是意外死亡溅话,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,426評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門歌焦,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)飞几,“玉大人,你說(shuō)我怎么就攤上這事独撇⌒寄” “怎么了?”我有些...
    開(kāi)封第一講書人閱讀 165,417評(píng)論 0 356
  • 文/不壞的土叔 我叫張陵纷铣,是天一觀的道長(zhǎng)卵史。 經(jīng)常有香客問(wèn)我,道長(zhǎng)搜立,這世上最難降的妖魔是什么以躯? 我笑而不...
    開(kāi)封第一講書人閱讀 58,868評(píng)論 1 295
  • 正文 為了忘掉前任,我火速辦了婚禮啄踊,結(jié)果婚禮上忧设,老公的妹妹穿的比我還像新娘。我一直安慰自己颠通,他們只是感情好址晕,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,892評(píng)論 6 392
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著顿锰,像睡著了一般谨垃。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上硼控,一...
    開(kāi)封第一講書人閱讀 51,692評(píng)論 1 305
  • 那天乘客,我揣著相機(jī)與錄音,去河邊找鬼淀歇。 笑死易核,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的浪默。 我是一名探鬼主播牡直,決...
    沈念sama閱讀 40,416評(píng)論 3 419
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼缀匕,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了碰逸?” 一聲冷哼從身側(cè)響起乡小,我...
    開(kāi)封第一講書人閱讀 39,326評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎饵史,沒(méi)想到半個(gè)月后满钟,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,782評(píng)論 1 316
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡胳喷,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,957評(píng)論 3 337
  • 正文 我和宋清朗相戀三年湃番,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片吭露。...
    茶點(diǎn)故事閱讀 40,102評(píng)論 1 350
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡吠撮,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出讲竿,到底是詐尸還是另有隱情泥兰,我是刑警寧澤,帶...
    沈念sama閱讀 35,790評(píng)論 5 346
  • 正文 年R本政府宣布题禀,位于F島的核電站鞋诗,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏迈嘹。R本人自食惡果不足惜师脂,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,442評(píng)論 3 331
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望江锨。 院中可真熱鬧,春花似錦糕篇、人聲如沸啄育。這莊子的主人今日做“春日...
    開(kāi)封第一講書人閱讀 31,996評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)挑豌。三九已至,卻和暖如春墩崩,著一層夾襖步出監(jiān)牢的瞬間氓英,已是汗流浹背。 一陣腳步聲響...
    開(kāi)封第一講書人閱讀 33,113評(píng)論 1 272
  • 我被黑心中介騙來(lái)泰國(guó)打工鹦筹, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留铝阐,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 48,332評(píng)論 3 373
  • 正文 我出身青樓铐拐,卻偏偏與公主長(zhǎng)得像徘键,于是被迫代替她去往敵國(guó)和親练对。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,044評(píng)論 2 355

推薦閱讀更多精彩內(nèi)容

  • rljs by sennchi Timeline of History Part One The Cognitiv...
    sennchi閱讀 7,334評(píng)論 0 10
  • 性別:女 愛(ài)好:唱歌 ... 性格: 愛(ài)笑 樂(lè)于助人 白亭 藍(lán)纓學(xué)院校草 愛(ài)好:唱歌 跳舞....
    涼笙墨盡閱讀 291評(píng)論 0 0
  • 月明星稀吹害,烏鵲南飛螟凭;繞樹三匝,無(wú)枝可依 —————————————— 曹操.短歌行
    老鱉閱讀 379評(píng)論 0 1