免费做微信请帖的网站怎么做好手机网站开发
2026/2/3 8:04:19 网站建设 项目流程
免费做微信请帖的网站,怎么做好手机网站开发,浙江注册公司网站,深圳网站建设q479185700強2092: 找出知晓秘密的所有专家思路#xff1a;排序bfs广度优先搜索假设一开始 0 和 1 知道秘密。对比如下两种情况#xff1a;时间 1#xff0c;1 和 2 开会。时间 2#xff0c;2 和 3 开会。秘密会传播给 2 和 3#xff0c;最终 0,1,2,3 都知道秘密。时间 1#xff0c;2…2092: 找出知晓秘密的所有专家思路排序bfs广度优先搜索假设一开始 0 和 1 知道秘密。对比如下两种情况时间 11 和 2 开会。时间 22 和 3 开会。秘密会传播给 2 和 3最终 0,1,2,3 都知道秘密。时间 12 和 3 开会。时间 21 和 2 开会。第一场会议参加会议的人都不知道秘密所以秘密不会传播。秘密只会在第二场会议传播给 2最终 0,1,2 都知道秘密。所以要按照开会的先后顺序传播秘密模拟这个过程。注意题目的这段话秘密共享是瞬时发生的。也就是说在同一时间一个专家不光可以接收到秘密还能在其他会议上与其他专家分享。解读在同一时间发生的所有会议可以视作一个无向图。专家是图中的节点meetings[i] 是图的边连接 xi 和 yi。这个图可能有多个连通块。每个连通块只要有一个人知道秘密那么整个连通块的人都能知道秘密。class Solution { public: vectorint findAllPeople(int n, vectorvectorint meetings, int firstPerson) { //按时间分组同一时间的会议放一个 vector 里 mapint,vectorpairint,int met_time; for(auto m:meetings) met_time[m[2]].emplace_back(m[0],m[1]); setint known{0,firstPerson}; //已知秘密的人 //按时间顺序处理map容器自动升序排序 for(auto [_,vec]:met_time){ unordered_mapint,vectorint g; setint nodes; //自动去重 //建图 for(auto [u,v]:vec){ g[u].push_back(v); g[v].push_back(u); nodes.insert(u); nodes.insert(v); } //把当前时刻已知的所有人当起点做 BFS queueint q; for(int x:nodes) if(known.count(x)) q.push(x); while(!q.empty()){ int uq.front();q.pop(); for(int v:g[u]){ if(!known.count(v)){ known.insert(v); q.push(v); } } } } vectorint ans(known.begin(), known.end()); return ans; } };

需要专业的网站建设服务?

联系我们获取免费的网站建设咨询和方案报价,让我们帮助您实现业务目标

立即咨询