news 2026/4/23 8:44:43

leetcode 2092(排序+bfs)

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
leetcode 2092(排序+bfs)

2092: 找出知晓秘密的所有专家

思路:排序+bfs广度优先搜索

假设一开始 0 和 1 知道秘密。对比如下两种情况:

  • 时间 1,1 和 2 开会。时间 2,2 和 3 开会。秘密会传播给 2 和 3,最终 0,1,2,3 都知道秘密。
  • 时间 1,2 和 3 开会。时间 2,1 和 2 开会。第一场会议,参加会议的人都不知道秘密,所以秘密不会传播。秘密只会在第二场会议传播给 2,最终 0,1,2 都知道秘密。

所以要按照开会的先后顺序传播秘密,模拟这个过程。

注意题目的这段话:

  • 秘密共享是瞬时发生的。也就是说,在同一时间,一个专家不光可以接收到秘密,还能在其他会议上与其他专家分享。

解读:在同一时间发生的所有会议,可以视作一个无向图。专家是图中的节点,meetings[i] 是图的边,连接 xi 和 yi。这个图可能有多个连通块。每个连通块只要有一个人知道秘密,那么整个连通块的人都能知道秘密。

class Solution { public: vector<int> findAllPeople(int n, vector<vector<int>>& meetings, int firstPerson) { //按时间分组,同一时间的会议放一个 vector 里 map<int,vector<pair<int,int>>> met_time; for(auto& m:meetings) met_time[m[2]].emplace_back(m[0],m[1]); set<int> known{0,firstPerson}; //已知秘密的人 //按时间顺序处理,map容器自动升序排序 for(auto& [_,vec]:met_time){ unordered_map<int,vector<int>> g; set<int> nodes; //自动去重 //建图 for(auto& [u,v]:vec){ g[u].push_back(v); g[v].push_back(u); nodes.insert(u); nodes.insert(v); } //把当前时刻已知的所有人当起点做 BFS queue<int> q; for(int x:nodes) if(known.count(x)) q.push(x); while(!q.empty()){ int u=q.front();q.pop(); for(int v:g[u]){ if(!known.count(v)){ known.insert(v); q.push(v); } } } } vector<int> ans(known.begin(), known.end()); return ans; } };
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/22 13:26:31

30分钟极速入门:LanceDB Java客户端实战指南

30分钟极速入门&#xff1a;LanceDB Java客户端实战指南 【免费下载链接】lancedb Developer-friendly, serverless vector database for AI applications. Easily add long-term memory to your LLM apps! 项目地址: https://gitcode.com/gh_mirrors/la/lancedb LanceD…

作者头像 李华
网站建设 2026/4/22 1:14:21

Obsidian主题定制终极指南:打造高效知识管理界面

Obsidian主题定制终极指南&#xff1a;打造高效知识管理界面 【免费下载链接】obsidian-california-coast-theme A minimalist obsidian theme inspired by macOS Big Sur 项目地址: https://gitcode.com/gh_mirrors/ob/obsidian-california-coast-theme Obsidian作为现…

作者头像 李华
网站建设 2026/4/23 12:24:03

Verl项目vLLM多GPU部署实战:5大挑战与高效解决方案

Verl项目vLLM多GPU部署实战&#xff1a;5大挑战与高效解决方案 【免费下载链接】verl verl: Volcano Engine Reinforcement Learning for LLMs 项目地址: https://gitcode.com/GitHub_Trending/ve/verl Verl项目作为火山引擎推出的强化学习框架&#xff0c;在大规模语言…

作者头像 李华
网站建设 2026/4/23 11:39:44

PostIn安装配置:轻量接口管理工具实操

给大家介绍一款开源免费的接口管理工具 - PostIn&#xff0c;支持免费私有化部署&#xff0c;一键安装零配置&#xff0c;包含项目管理、接口调试、接口文档设计、MOCK、接口用例、性能测试、测试计划等模块&#xff0c;页面设计简洁易用&#xff0c;本文将介绍如何快速安装配…

作者头像 李华
网站建设 2026/4/23 1:00:48

WAN2.2-14B-Rapid-AllInOne:让AI视频创作从专业走向普及

WAN2.2-14B-Rapid-AllInOne&#xff1a;让AI视频创作从专业走向普及 【免费下载链接】WAN2.2-14B-Rapid-AllInOne 项目地址: https://ai.gitcode.com/hf_mirrors/Phr00t/WAN2.2-14B-Rapid-AllInOne 你是否曾经梦想过用AI生成视频&#xff0c;却被高昂的硬件门槛和复杂的…

作者头像 李华
网站建设 2026/4/23 11:43:00

Ursa.Avalonia无障碍设计:5分钟快速构建包容性用户界面

Ursa.Avalonia无障碍设计&#xff1a;5分钟快速构建包容性用户界面 【免费下载链接】Ursa.Avalonia Ursa是一个用于开发Avalonia程序的控件库 项目地址: https://gitcode.com/IRIHI_Technology/Ursa.Avalonia 在当今数字化时代&#xff0c;构建真正包容的应用程序已成为…

作者头像 李华