[PAT解题报告] The Largest Generation

简单题,给定一棵树——树是按照父子关系给出的,求节点个数最多的那层有多少个节点——保证这层是唯一的。并且认为根的层数为1。
因为数非空,并且规定了根是1号,我把id都减去1之后,就认为第0层是根。用d[]表示每个节点的层数,即深度。用num[]表示每层的节点数。别忘记初值d[0] = 1, num[1] = 1。
读入树结构的时候,我们记录每个节点x的父亲y,即f[x] = y。 则d[x] = d[y] + 1。我们dfs求出每个节点的深度——注意如果之前求过,递归可以直接返回,所以计算深度是O(n)的,相当于dfs整个树。我用了全局变量,没求过的深度暂且认为0。当然也可以从根直接dfs一次直接得到每个节点的深度,写起来比我现在这个稍微麻烦一点,总之可以求出每个节点的深度,顺便累加到num[d[x]]上面去,就能求出节点数最多的层了。

代码;

#include <cstdio>
#include <cstring>
#include <string>

using namespace std;

int f[105];
int d[105] = {1};
int num[105] = {0, 1};

int getd(int i) {
    return d[i]?d[i]:(d[i] = getd(f[i]) + 1);
}

int main() {
int n, m;
    for (scanf("%d%d", &n,&m);m;--m) {
        int x, i;
        scanf("%d%d",&x,&i);
        for (--x; i; --i) { 
            int y;
            scanf("%d", &y);
            f[y - 1] = x;
        }
    }
    m = 1;
    for (int i = 1; i < n; ++i) {
        int temp = getd(i);
        if (++num[temp] > num[m]) {
            m = temp;
        }
    }
    printf("%d %d\n", num[m], m);
    return 0;
}
原题链接: http://www.patest.cn/contests/pat-a-practise/1094
全部评论
想问下你那个getd()函数,如果把d数组都设为1什么时候会进入 d[i] = getd(f[i]) + 1
点赞 回复 分享
发布于 2016-09-12 21:59

相关推荐

“无名小卒,还是名扬天下?”我知道很多人都不觉得我能走到今天这一步,当然,也包括我自己。在我的人生里,有两部作品刻下了最深的烙印:《斗破苍穹》与《龙族》。它们总被人拿来对照:一边是萧炎的桀骜轻狂,一边是路明非的怯懦衰颓。有人说,天蚕土豆没见过魂天帝,但江南见过真凯撒。我时常觉得,自己就是那个衰小孩路明非。可路明非可以开挂,我不可以;我也无数次幻想过,能拥有萧炎那般年少轻狂的人生,可我没有他与生俱来的逆天天赋。我只是个平庸的普通人,一个看过《斗破苍穹》却开不了挂的路明非,只能一步一步往上爬。从我下定决心找实习的那一刻起,我就给自己定下了目标:“我一定要为字节跳动卖命.jpg”。萧炎有他的三年之约,我有我的两年半之约(其实是一年半)。2024.11.20,科大讯飞的第一封实习offer落进邮箱,我迈出了这场奔赴的第一步。2025.8.18,放弃百度转正的安稳机会,转身走进前路未卜的不确定里。我很感谢我在百度的mentor,是她从茫茫人海选中了我,给了我大厂实习的机会。即便有段时间我状态差、产出不理想,她依旧愿意认可我、希望我留下转正。2025.11.14,我选择走进字节跳动,以实习生的身份重新出发。2026.3.25&nbsp;-&nbsp;3.31,一周速通上海飞书,幸遇赏识我的伯乐,斩获Special&nbsp;Offer。被告知面试通过的那一刻,我的内心无比平静,就像这个offer本就该属于我。不是侥幸,是应得的。这一路,有人看轻过我的出身,不相信我能走到这里;也有人在我看不见前路的时候,替我举过灯。没有他们的鼓励与支撑,就没有今天站在这里的我。我看到了自强不息的激荡,那是一个双非的伟大乐章!我是雨夜迈巴赫,我要开启属于我的新篇章了。
在看牛客的本杰明很勇...:真心祝贺l总 我永远的偶像 我滴神
春招至今,你收到几个面试...
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务