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

东莞市建设培训中心网站个人小程序怎么做

东莞市建设培训中心网站,个人小程序怎么做,wordpress 4.8 rest api,wordpress取消手机版本文涉及知识点 CBFS算法 LeetCode690. 员工的重要性 你有一个保存员工信息的数据结构,它包含了员工唯一的 id ,重要度和直系下属的 id 。 给定一个员工数组 employees,其中: employees[i].id 是第 i 个员工的 ID。 employees[…

本文涉及知识点

C++BFS算法

LeetCode690. 员工的重要性

你有一个保存员工信息的数据结构,它包含了员工唯一的 id ,重要度和直系下属的 id 。
给定一个员工数组 employees,其中:
employees[i].id 是第 i 个员工的 ID。
employees[i].importance 是第 i 个员工的重要度。
employees[i].subordinates 是第 i 名员工的直接下属的 ID 列表。
给定一个整数 id 表示一个员工的 ID,返回这个员工和他所有下属的重要度的 总和。
示例 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:

在这里插入图片描述

输入: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 都有效。

C++BFS

根据生活常识,我们假定没有任何两位员工互为领导。如果互为领导,本题无法计算。
我们令 本人是自己的0层下属,直接下属是1层下属,直接下属的直接下属是二级下属…
leves[i]记录id 的i层下属。
BFS的状态表示:cur。
BFS的后续状态:cur的直接下属。
BFS的初始状态:leves[0] = {id};
BFS的返回值,所有的cur重要性之和。
BFS的重复处理:根据生活常识,无需处理重复。
预处理:向量vIDtoPtr记录 各id对应的员工信息。

代码

核心代码

class Employee {public:int id;int importance;vector<int> subordinates;};class Solution {public:int getImportance(vector<Employee*> employees, int id) {vector<Employee*> vIDToPtr(2000 + 1);for ( auto& ptr : employees) {vIDToPtr[ptr->id] = ptr;}queue<int > que;que.emplace(id);int ret = 0;while (que.size()) {int cur = que.front();que.pop();auto ptr = vIDToPtr[cur];ret += ptr->importance;for (const auto& next : ptr->subordinates) {que.emplace(next);}}return ret;}};

单元测试

namespace LeetCode690
{//LeetCode690. 员工的重要性TEST_CLASS(LeetCode690){public:class Employee {public:int id;int importance;vector<int> subordinates;};class Solution {public:int getImportance(vector<Employee*> employees, int id) {vector<Employee*> vIDToPtr(2000 + 1);for ( auto& ptr : employees) {vIDToPtr[ptr->id] = ptr;}queue<int > que;que.emplace(id);int ret = 0;while (que.size()) {int cur = que.front();que.pop();auto ptr = vIDToPtr[cur];ret += ptr->importance;for (const auto& next : ptr->subordinates) {que.emplace(next);}}return ret;}};vector<Employee> employees;vector<Employee*> ToPtr(vector<Employee>& employees) {vector<Employee*> ret;for (auto& e : employees) {ret.emplace_back(&e);}return ret;}int id;TEST_METHOD(TestMethod1){employees = { {1,5,{2,3}},{2,3,{}},{3,3,{}} }, id = 1;auto res = Solution().getImportance(ToPtr(employees), id);AssertEx(11, res);}TEST_METHOD(TestMethod2){employees = { {1,2,{5}},{5,-3,{}} }, id = 5;auto res = Solution().getImportance(ToPtr(employees), id);AssertEx(-3, res);}};
}


如果有不明白的,请加文末QQ群。

扩展阅读

视频课程

先学简单的课程,请移步CSDN学院,听白银讲师(也就是鄙人)的讲解。
https://edu.csdn.net/course/detail/38771

如何你想快速形成战斗了,为老板分忧,请学习C#入职培训、C++入职培训等课程
https://edu.csdn.net/lecturer/6176

相关推荐

我想对大家说的话
《喜缺全书算法册》以原理、正确性证明、总结为主。
按类别查阅鄙人的算法文章,请点击《算法与数据汇总》。
有效学习:明确的目标 及时的反馈 拉伸区(难度合适) 专注
闻缺陷则喜(喜缺)是一个美好的愿望,早发现问题,早修改问题,给老板节约钱。
子墨子言之:事无终始,无务多业。也就是我们常说的专业的人做专业的事。
如果程序是一条龙,那算法就是他的是睛

测试环境

操作系统:win7 开发环境: VS2019 C++17
或者 操作系统:win10 开发环境: VS2022 C++17
如无特殊说明,本算法用**C++**实现。

http://www.yayakq.cn/news/730838/

相关文章:

  • 南宁公司网站建设方案网站搭建的人
  • 租车网站开发菏泽手机网站建设
  • 房山区做网站做网站优化就是发文章吗
  • 网站建设 中企动力鄂ICP备如何做网站的301重定向
  • 网站怎么防黑客开发一个软件需要什么过程
  • 江门有那几间公司做网站的东莞活动外包
  • 开通网站流程织梦网站会员上传图片
  • 南京律师网站建设汽车金融网站怎么做
  • 企业运营网站建设河南新乡市建设银行网站
  • 两个网站开发swot分析网站前置审批表
  • 诚信经营网站的建设网页导航栏设计图片
  • 网站建设招标方案今天国内最新消息
  • wordpress在哪里设置关键词和描述网站seo查询站长之家
  • 如何在网站做宣传推荐几个的网站
  • 昆明企业网站建设一条龙wordpress防止攻击
  • 权威行业网站建设公司网站建设 乐达云创
  • 网站建设方案书 icp备案杨幂做的网站广告
  • 我的网站模板下载网站建设公司网页
  • 网站流量提升方法注册公司怎么查询
  • 大钢模板相关信息圆柱钢模板优势是什么?企业网站建设模板和定制化有什么区别呢?人工费多少钱一平方比较火的网页游戏
  • app下载网站免费wordpress彩色
  • 安防公司网站模板做开锁推广什么网站好
  • 全国美容网站建设wordpress如何免费导入音频
  • 内部网站建设教程微信app下载安装官方版2019
  • 什么叫企业网站用框架做网站如何居中
  • 白云网站 建设信科网络WordPress rss连接
  • 做文案的人看什么网站求一个旅游网站的代码
  • 网站规划与建设大作业自己制作上传图片的网站怎么做
  • 重庆承越网站建设地址w3c网站模板
  • 那些网站被k恢复是怎么做的外贸做那种网站有哪些