zoukankan      html  css  js  c++  java
  • 690. 员工的重要性

    题目:给定一个保存员工信息的数据结构,它包含了员工 唯一的 id ,重要度 和 直系下属的 id 。比如,员工 1 是员工 2 的领导,员工 2 是员工 3 的领导。他们相应的重要度为 15 , 10 , 5 。那么员工 1 的数据结构是 [1, 15, [2]] ,员工 2的 数据结构是 [2, 10, [3]] ,员工 3 的数据结构是 [3, 5, []] 。注意虽然员工 3 也是员工 1 的一个下属,但是由于 并不是直系 下属,因此没有体现在员工 1 的数据结构中。现在输入一个公司的所有员工信息,以及单个员工 id ,返回这个员工和他所有下属的重要度之和。

    示例:

    输入:[[1, 5, [2, 3]], [2, 3, []], [3, 3, []]], 1
    输出:11
    解释:
    员工 1 自身的重要度是 5 ,他有两个直系下属 2 和 3 ,而且 2 和 3 的重要度均为 3 。因此员工 1 的总重要度是 5 + 3 + 3 = 11 。

    题解:

    /*
    // Definition for Employee.
    class Employee {
    public:
        int id;
        int importance;
        vector<int> subordinates;
    };
    */
    
    class Solution {
    public:
        int imp = 0;
        void gT(vector<Employee*> employees, int id){
            for(auto arr:employees){
                if(arr->id == id){ 
                    imp += arr->importance;
                    cout<<imp;
                    if((arr->subordinates).size() == 0) return;
                    for(int &m:arr->subordinates){
                        gT(employees, m);
                    }
                }
            }
        }
        int getImportance(vector<Employee*> employees, int id) {
            gT(employees, id);
            return imp;
        }
    };
  • 相关阅读:
    WPF之长短
    MFC程序和Win32程序的关系
    .NET Framework/CLR之长短
    常用软件
    经典推荐.Net面试法宝
    socket编程原理
    常用开发工具
    Get和Post方法的区别
    MAC IP等相关
    Datagrid为什么不自动换行显
  • 原文地址:https://www.cnblogs.com/USTC-ZCC/p/14649046.html
Copyright © 2011-2022 走看看