4.17华为笔试

第二题:

代码:前面细节没处理好,考完了才改好

import java.util.HashMap;
import java.util.LinkedList;
import java.util.Map;
import java.util.Scanner;

public class Main {
    public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);
        String str = sc.nextLine() ;
        String[] arr = str.split(" ") ;
        int m = Integer.valueOf(arr[0]) ;
        int n = Integer.valueOf(arr[1]) ;
        Map<String,TreeNode> map = new HashMap<>() ;
        for(int i=0;i<n;i++){
            //获取一行记录
            String temp = sc.nextLine() ;
            String[] arrays = temp.split(" ") ;
            //记录当前节点
            TreeNode node ;
            if(map.containsKey(arrays[0])){
                node = map.get(arrays[0]) ;
                if("0".equals(arrays[2])){
                    node.questionOne += Integer.valueOf(arrays[3]) ;
                }else{
                    node.questionTwo += Integer.valueOf(arrays[3]) ;
                }
            }else{
                if("0".equals(arrays[2])){//严重问题
                    node = new TreeNode(arrays[0],Integer.valueOf(arrays[3]),0) ;
                }else{//一般问题
                    node = new TreeNode(arrays[0],0,Integer.valueOf(arrays[3])) ;
                }
                //保存当前节点
                map.put(node.val,node) ;
            }

            //在父节点当中保存当前节点为子节点
            if(!map.containsKey(arrays[1])){
                map.put(arrays[1],new TreeNode(arrays[1],0,0)) ;
            }
            TreeNode parent = map.get(arrays[1]) ;
            boolean flag = true ;
            for(int j=0;j<parent.childrens.size();j++){
                if(parent.childrens.get(j).val == node.val){
                    flag = false ;
                    break;
                }
            }
            if(flag){
                parent.childrens.add(node) ;
            }

        }
        int ans = 0 ;
        TreeNode root = map.get("*") ;
        for(int i=0;i<root.childrens.size();i++){
            TreeNode node = root.childrens.get(i) ;
            int number = dfs(node) ;
            //System.out.println(root.childrens.get(i).val + "  " + number) ;
            if(number > m){
                ans++ ;
            }
        }
        System.out.println(ans) ;

    }
    public static int dfs(TreeNode root){
        if(root == null){
            return 0 ;
        }
        int sum = 0 ;
        for(int i=0;i<root.childrens.size();i++){
            sum += dfs(root.childrens.get(i)) ;
        }
        sum += root.questionOne * 5 + 2 * root.questionTwo ;
        return sum ;
    }
}
class TreeNode{
    String val ;
    //严重问题
    int questionOne ;
    //一般问题
    int questionTwo ;
    LinkedList<TreeNode> childrens ;
    public TreeNode(){

    }
    public TreeNode(String val,int questionOne,int questionTwo){
        this.val = val ;
        this.questionOne = questionOne ;
        this.questionTwo = questionTwo ;
        childrens = new LinkedList<>() ;
    }
}

全部评论
我这道是第二题欸
1 回复 分享
发布于 2024-04-18 10:16 广东

相关推荐

🔌插電的小米大冰箱:很喜欢放牛,因为牛不会在我翻过第四座山后跟我说第一座山的草好吃
点赞 评论 收藏
分享
不愿透露姓名的神秘牛友
2024-11-23 10:38
沉淀一会:**圣经 1.同学你面试评价不错,概率很大,请耐心等待;2.你的排名比较靠前,不要担心,耐心等待;3.问题不大,正在审批,不要着急签其他公司,等等我们!4.预计9月中下旬,安心过节;5.下周会有结果,请耐心等待下;6.可能国庆节前后,一有结果我马上通知你;7.预计10月中旬,再坚持一下;8.正在走流程,就这两天了;9.同学,结果我也不知道,你如果查到了也告诉我一声;10.同学你出线不明朗,建议签其他公司保底!11.同学你找了哪些公司,我也在找工作。
点赞 评论 收藏
分享
2024-12-04 19:53
已编辑
湖南文理学院 产品经理
牛客224543458号:他想找牛马,愿意疯狂加班的,因为要证明自己
点赞 评论 收藏
分享
评论
3
6
分享
牛客网
牛客企业服务