搜狗笔试-第二题

第一题超时。。
第三题没看。。
第二题70%(不知道哪些样例没考虑到?)
import sys


line1 = sys.stdin.readline().strip()
value1 = list(map(int, line1.split()))
k = value1[0]
n = value1[1]

tree = {}
for i in range(n):
    line2 = sys.stdin.readline().strip()
    value2 = list(map(int, line2.split()))
    tree[value2[1]] = (value2[0]-1, value2[2:])


def max_time(root):
    if root in tree:
        sub = tree[root][1]
        sub_time = []
        for s in sub:
            sub_time.append(max_time(s))
        sub_time.sort(reverse=True)

        y = 1
        z = k

        while z < len(sub_time):
            if sub_time[z] == sub_time[0]:
                y += 1
                z += k
            else:
                break
        return sub_time[0]+y

    return 0


res = max_time(0)
print(res)



#搜狗##笔试题目#
全部评论
我想了下,也是树形dp,思路和你的写法类似,等真题出来自己试一下。找到一个类似的题目 https://www.luogu.org/problem/P2018 区别在于笔试的题不用枚举根以及一个单位时间分发一个消息和k个消息。
点赞 回复 分享
发布于 2019-09-08 23:52
嗷我好像知道哪里有问题了_(:_」∠)_,计算y的时候if判断的时候要更新节点而不是一直sub_time[0]
点赞 回复 分享
发布于 2019-09-09 01:40
求第二题题面,谢谢楼主
点赞 回复 分享
发布于 2019-09-08 23:16
大佬,第一题输入怎么弄的?渣渣一直卡在了输入上
点赞 回复 分享
发布于 2019-09-08 23:15
求大佬第二题思路??
点赞 回复 分享
发布于 2019-09-08 20:46
我先求深度,然后模拟分发,优先给深度更深、子节点数更多的节点分发,过了0.8 但我觉得lz的思路更靠谱,然而我看不懂python
点赞 回复 分享
发布于 2019-09-08 19:43
第二题什么思路讲解下呗
点赞 回复 分享
发布于 2019-09-08 18:20

相关推荐

06-26 15:33
青岛工学院 Java
积极的秋田犬要冲国企:他现在邀请我明天面试
点赞 评论 收藏
分享
屌丝逆袭咸鱼计划:心态摆好,man,晚点找早点找到最后都是为了提升自己好进正职,努力提升自己才是最关键的😤难道说现在找不到找的太晚了就炸了可以鸡鸡了吗😤早实习晚实习不都是为了以后多积累,大四学长有的秋招进的也不妨碍有的春招进,人生就这样
点赞 评论 收藏
分享
不愿透露姓名的神秘牛友
07-15 17:09
点赞 评论 收藏
分享
评论
2
7
分享

创作者周榜

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