当前位置: 首页 > news >正文

【LeetCode:690】员工的重要性(Java)

题目链接

  • 690. 员工的重要性

题目描述

你有一个保存员工信息的数据结构,它包含了员工唯一的 id ,重要度和直系下属的 id 。

给定一个员工数组 employees,其中:

employees[i].id 是第 i 个员工的 ID。
employees[i].importance 是第 i 个员工的重要度。
employees[i].subordinates 是第 i 名员工的直接下属的 ID 列表。
给定一个整数 id 表示一个员工的 ID,返回这个员工和他所有下属的重要度的 总和。

示例 1:
1

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

示例 2:
2

输入:employees = [[1,2,[5]],[5,-3,[]]], id = 5
输出:-3
解释:员工 5 的重要度为 -3 并且没有直接下属。
因此,员工 5 的总重要度为 -3。

提示:

1 <= employees.length <= 2000
1 <= employees[i].id <= 2000
所有的 employees[i].id 互不相同。
-100 <= employees[i].importance <= 100
一名员工最多有一名直接领导,并可能有多名下属。
employees[i].subordinates 中的 ID 都有效。

求解思路1

  • 深搜(DFS):通过哈希表将员工的id和员工进行映射,方便后续查找。搜索指定id员工的所有直接下属员工,并将其重要性值累加即可。

实现代码1

/*
// Definition for Employee.
class Employee {public int id;public int importance;public List<Integer> subordinates;
};
*/class Solution {Map<Integer, Employee> map = new HashMap<>();public int getImportance(List<Employee> employees, int id) {for (Employee e : employees) {map.put(e.id, e);}return dfs(id);}public int dfs(int id) {Employee e = map.get(id);int sum = e.importance;List<Integer> subordinates = e.subordinates;// 搜索该id员工的所有直属员工for (int s : subordinates) {sum += dfs(s);}return sum;}
}

求解思路2

  • 宽搜(BFS):同样需要创建哈希表将员工id和员工进行映射。创建队列,每次遍历该员工出队后,将该员工的所有直接下属员工全部入队继续遍历,累加得到结果。

实现代码2

/*
// Definition for Employee.
class Employee {public int id;public int importance;public List<Integer> subordinates;
};
*/class Solution {public int getImportance(List<Employee> employees, int id) {Map<Integer, Employee> map = new HashMap<>();for (Employee e : employees) {map.put(e.id, e);}int sum = 0;Queue<Integer> queue = new LinkedList<>();queue.offer(id);while (!queue.isEmpty()) {int curId = queue.poll();Employee employee = map.get(curId);sum += employee.importance;// 将出队员工的所有直属员工入队List<Integer> subordinates = employee.subordinates;for (int s : subordinates) {queue.offer(s);}}return sum;}
}

http://www.mrgr.cn/news/9592.html

相关文章:

  • c++枚举类型StarPU实现矩阵乘
  • 趋动科技联合云轴科技推出GPU云原生超融合解决方案
  • ELK进阶-安全认证设置流程介绍
  • Python算法工程师面试整理-离散数学
  • TOMCAT全解
  • C语言典型例题51
  • 使用Java进行中小学违规教育培训数据采集实践-以某城市为例
  • pytorch, torch_tesnsorrt安装各版本匹配
  • (152)时序收敛--->(02)时序收敛二
  • HTTP与Qt:构建网络应用的桥梁
  • 矢量数据创建
  • 前端性能优化:构建快速且流畅的Web体验
  • 基于pygame的雷电战机小游戏
  • 【初阶数据结构】顺序表和链表算法题(上)
  • SpringCloud Gateway及 Springboot 服务 跨域配置
  • 【Tesla FSD V12的前世今生】从模块化设计到端到端自动驾驶技术的跃迁
  • 使用 Vue I18n 进行 Vue.js 应用的国际化
  • Java超市收银系统(十、爬虫)
  • vue 精选评论词云 集成echarts-wordcloud TF-IDF算法
  • PDF文件切割,无大小限制