携程0329开发笔试题解

投票
T1 计算圆圈个数 直接计数即可
T2 排列构造,需要K个好元素。只需要选择0, 2, 4,..., 2*(k-1)下标的地方依次填入n-k+1, n-k+2, ... ,n,也就是倒数k大的数,剩下的地方把剩下的地方填写即可
T3 x的阶乘范围决定了x不会超过15,枚举x,然后y取n/x和(n/x)+1计算哪个绝对值小即可。注意x和y不能取2,但可能取1。提交时感觉有个样例bug,x取1时按理说y直接消了取多少都可以,但是取n不通过,取1就通过了。
T4 树形DP,直接DFS,计算孩子允许染色和不允许染色的情况,返回两个状态:一个是不允许自己和孩子之间染色,一个是允许,两种情况下的权值。核心参考代码如下:    
def dfs(node):
    draw, nodraw, drawed = [], [], [] # 存储孩子状态
    for nei, W in G[node]:
       if not flag[nei]:
           flag[nei] = True
           neiNoDraw, neiDraw = dfs(nei)
           nodraw.append(neiNoDraw)
           draw.append(neiDraw)
           drawed.append(W + neiNoDraw)
    if draw: # 如果不是叶子
       noDrawAns = sum(map(max, zip(draw, nodraw)))  
       drawDiff = [drawed[i] - draw[i] for i in range(len(draw))] 
       maxDiffIndex = drawDiff.index(max(drawDiff))
       drawAns = max(noDrawAns, drawed[maxDiffIndex]+sum(draw)-draw[maxDiffIndex]) 
       return noDrawAns, drawAns
    return 0, 0
全部评论
大佬太强了
点赞 回复 分享
发布于 2023-03-29 21:13 广东
a了前两个,第三个一直是61.1,最后一个直接放弃
点赞 回复 分享
发布于 2023-03-29 21:15 辽宁
补充下细节: T3 X枚举,然后Y直接取n/X和(n/X)+1计算哪个绝对值小即可; T4 允许自己和孩子之间染色这个状态即drawAns的计算需要注意一下,应该选择与哪一个孩子染色呢?应当对每一个孩子考虑,“选择与它染色得到的最大权值”和“不选择与它染色”得到的最大权值之差,即代码中的drawDiff,这个差最大的就是染色对权值贡献最大的孩子,我们选择与它染色。
点赞 回复 分享
发布于 2023-03-29 21:21 广东
有霉粉啊
点赞 回复 分享
发布于 2023-03-30 20:57 广东

相关推荐

嗷佛快来快来快快快来:我当时就是听了别人的谣言,环境的大变,左右摇摆不定,到最后一事无成。我也给你提不了什么有效的建议,因为我自己就是败犬。但是我确实是从cpp转到了Java,cpp也做过项目,了解过具体的细分方向。如果你感兴趣,不会拦你。因为只要一件事情能坚持下去 就会发光
点赞 评论 收藏
分享
雨夜迈巴赫:哪个厂呀
点赞 评论 收藏
分享
评论
2
2
分享
牛客网
牛客企业服务