【C++BFS】690. 员工的重要性

2024-07-13 1034阅读

本文涉及知识点

C++BFS算法

LeetCode690. 员工的重要性

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

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

employees[i].id 是第 i 个员工的 ID。

employees[i].importance 是第 i 个员工的重要度。

employees[i].subordinates 是第 i 名员工的直接下属的 ID 列表。

给定一个整数 id 表示一个员工的 ID,返回这个员工和他所有下属的重要度的 总和。

示例 1:

【C++BFS】690. 员工的重要性

输入: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:

【C++BFS】690. 员工的重要性

输入:employees = [[1,2,[5]],[5,-3,[]]], id = 5

输出:-3

解释:员工 5 的重要度为 -3 并且没有直接下属。

因此,员工 5 的总重要度为 -3。

提示:

1 public: int id; int importance; vector public: int getImportance(vector vector vIDToPtr[ptr-id] = ptr; } queue int cur = que.front(); que.pop(); auto ptr = vIDToPtr[cur]; ret += ptr-importance; for (const auto& next : ptr-subordinates) { que.emplace(next); } } return ret; } }; //LeetCode690. 员工的重要性 TEST_CLASS(LeetCode690) { public: class Employee { public: int id; int importance; vector public: int getImportance(vector vector vIDToPtr[ptr-id] = ptr; } queue 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 employees; vector ToPtr(vector& employees) { vector 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); } }; }

【C++BFS】690. 员工的重要性

如果有不明白的,请加文末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++**实现。

【C++BFS】690. 员工的重要性

VPS购买请点击我

免责声明:我们致力于保护作者版权,注重分享,被刊用文章因无法核实真实出处,未能及时与作者取得联系,或有版权异议的,请联系管理员,我们会立即处理! 部分文章是来自自研大数据AI进行生成,内容摘自(百度百科,百度知道,头条百科,中国民法典,刑法,牛津词典,新华词典,汉语词典,国家院校,科普平台)等数据,内容仅供学习参考,不准确地方联系删除处理! 图片声明:本站部分配图来自人工智能系统AI生成,觅知网授权图片,PxHere摄影无版权图库和百度,360,搜狗等多加搜索引擎自动关键词搜索配图,如有侵权的图片,请第一时间联系我们,邮箱:ciyunidc@ciyunshuju.com。本站只作为美观性配图使用,无任何非法侵犯第三方意图,一切解释权归图片著作权方,本站不承担任何责任。如有恶意碰瓷者,必当奉陪到底严惩不贷!

目录[+]