猿辅导笔试第二题(Java版)-小猿抽奖

第二题参考大佬发的帖子,自己整理成了Java版,如有不对还请指正~

HashMap + DFS 进行求解

用Hashmap存储边之间的关系,然后依据节点之间的关系进行查找最大值。

package YuanFuDao;

import java.util.*;

public class Main {

    public static int dfs(int rt, int ans,int[] val, HashMap<Integer,LinkedList<Integer>> map){
        int ret = val[rt];
        if (map.containsKey(rt)){
            LinkedList<Integer> list = map.get(rt);
            for (int v :
                    list) {
                ret = Math.max(ret, ret + dfs(v,ans,val,map));
            }
        }
        ans = Math.max(ans, ret);
        return ans;
    }
    public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);
        int N = sc.nextInt();
        int[] val = new int[N];
        int rt = -1;
        HashMap<Integer, LinkedList<Integer>> map = new HashMap<>();
        for (int i = 0; i < N; i++) {
            int fa;
            val[i] = sc.nextInt();
            fa = sc.nextInt();
            if (fa == 0){
                rt = i;
            }else {
                int res = fa - 2;
               if (map.containsKey(res)){
                   LinkedList<Integer> list = map.get(res);
                   list.add(i);
               }else {
                   LinkedList<Integer> list = new LinkedList<>();
                   list.add(i);
                   map.put(res,list);
               }

            }

        }

        int ans = Integer.MIN_VALUE;
        int dfs = dfs(rt, ans, val, map);
        System.out.println("Max: "+dfs);
    }
}


#笔试题目##猿辅导#
全部评论
可以说下笔试题什么类型吗
点赞 回复 分享
发布于 2020-08-18 21:58
题目是啥呀
点赞 回复 分享
发布于 2020-08-17 22:25

相关推荐

不愿透露姓名的神秘牛友
07-11 11:24
大家还是用ai改吧,我心疼得要死,就当花钱买教训吧,人家直接拿完钱就跑路了
程序员小白条:简历修改700....神奇,又不是帮你面试,咋的,简历修改从双非变92了还是没实习变成有大厂实习了
点赞 评论 收藏
分享
06-26 15:33
青岛工学院 Java
积极的秋田犬要冲国企:他现在邀请我明天面试
点赞 评论 收藏
分享
Twilight_m...:表格简历有点难绷。说说个人看法: 1.个人基本情况里好多无意义信息,什么婚姻状况、健康状况、兴趣爱好、户口所在地、身份证号码、邮政编码,不知道的以为你填什么申请表呢。 2.校内实践个人认为对找工作几乎没帮助,建议换成和测开有关的项目,实在没得写留着也行。 3.工作经历完全看不出来是干什么的,起码看着和计算机没啥关系,建议加强描述,写点你在工作期间的实际产出、解决了什么问题。 4.个人简述大而空,看着像AI生成,感觉问题最大。“Python,C,C++成为我打造高效稳定服务的得力工具”、“我渴望凭借自身技术知识与创新能力,推动人工智能技术的应用发展,助力社会实现智能化转型”有种小学作文的美感。而且你确定你个人简述里写的你都会嘛?你AI这块写的什么“深入研究”,发几篇顶会的硕博生都不一定敢这么写。而且你AI这块的能力和软测也完全无关啊。个人简述建议写你对哪些技术栈、哪些语言、哪些生产工具的掌握,写的有条理些,而且最好是和测开强相关的。
点赞 评论 收藏
分享
不愿透露姓名的神秘牛友
昨天 17:24
点赞 评论 收藏
分享
评论
1
4
分享

创作者周榜

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