news 2026/4/17 18:00:05

leetcode 困难题 815. Bus Routes 公交路线

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
leetcode 困难题 815. Bus Routes 公交路线

Problem: 815. Bus Routes 公交路线

解题过程

抽象,不考虑站点的邻接表,更上一层的,考虑bus之间的邻接表

用每个站点做邻接表,然后用Dijkstra或者深度优先搜索dfs都超时了,或者超内存了。考虑到每辆bus在这个路径内都是联通的,所以每个bus做一个节点node,routes长度<500,每个bus写出邻接表,相比每个站点做邻接表,占用的内存大大减小,只需要考虑bus之间是否联通即可,不单独考虑站点之间。只要source所在的bus和target所在的bus是联通的即可,拿到最短路径就行了

bus之间是否相连的话,首先用哈希表存储每个站点的bus索引i的ump[routes[i][j]].insert(i);,这样每个站点的bus索引就拿到了,顺便存储source和target的索引,然后构造邻接表即可trr[p1].push_back(p2);, trr[p2].push_back(p1);。

因source可能存在于多个bus的索引内,所以从每个source可能的索引开始,都使用深度优先搜索,或者Dijkstra,这样target可能的索引的最短距离就是答案

Code

class Solution { public: vector<vector<pair<int, int>>> tr; vector<vector<int>> trr; vector<vector<bool>> status; unordered_map<int, int> ump; pair<int, int> point; int mi = INT_MAX; void dfs(vector<vector<int>>& routes, int source, int target, int ii, int jj) { int i, j, next; if(source == target) { mi = min(mi, (int)ump.size()); } status[ii][jj] = true; ump[ii]++; for(int k = 0; k < tr[source].size(); k++) { point = tr[source][k]; i = point.first; j = point.second; if(status[i][j] == false) { next = routes[i][j]; dfs(routes, next, target, i, j); } } status[ii][jj] = false; ump[ii]--; if(ump[ii]==0) { ump.erase(ii); } } unordered_set<int> tC, tmptmp; vector<int> ttCC; vector<bool> statusSTATUS; int minmin = INT_MAX; void dfsdfs(int start) { tmptmp.insert(start); if(tC.find(start) != tC.end()) { minmin = min(minmin, (int)tmptmp.size()); } statusSTATUS[start] = true; int next; for(int i = 0; i < trr[start].size(); i++) { next = trr[start][i]; if(statusSTATUS[next] == false) { dfsdfs(next); } } tmptmp.erase(start); statusSTATUS[start] = false; } int numBusesToDestination(vector<vector<int>>& routes, int source, int target) { if(source == target) return 0; trr.resize(routes.size()); statusSTATUS.assign(routes.size(), false); vector<int> sC; unordered_map<int, unordered_set<int>> ump; for( int i = 0; i < routes.size(); i++ ) { bool s = false, t = false; for( int j = 0; j < routes[i].size(); j++ ) { if(routes[i][j] == source) { sC.push_back(i); s = true; } if(routes[i][j] == target) { tC.insert(i); ttCC.push_back(i); t = true; } ump[routes[i][j]].insert(i); } // if(s == true && t==true) return 1; } unordered_set<int>::iterator it; unordered_map<int, vector<int>> umpump; for(auto [key, value] : ump) { for(it = value.begin(); it != value.end(); it++) { umpump[key].push_back(*it); } } int p1, p2; for(auto [key, value] : umpump) { for(int i = 0; i < value.size(); i++) { p1 = value[i]; p2 = value[(i+1)%(int)value.size()]; trr[p1].push_back(p2); trr[p2].push_back(p1); } } // for(int i = 0; i < sC.size(); i++) { // dfsdfs(sC[i]); // } // if(minmin==INT_MAX) return -1; // return minmin; // int ret = 0, mx = INT_MIN; // vector<pair<int, int>> sourceCOL; // for( int i = 0; i < routes.size(); i++ ) { // int n = routes[i].size(); // bool s = false, t = false; // for(int j = 0; j < n; j++) { // mx = max(mx, routes[i][j]); // if(routes[i][j]==source) s = true; // if(routes[i][j] == target) t = true; // if(s == true && t==true) return 1; // } // } // tr.resize(mx + 1); // for( int i = 0; i < routes.size(); i++ ) { // int n = routes[i].size(); // vector<bool> tmp(n, false); // status.push_back(tmp); // int p1, p2; // for(int j = 0; j < n; j++) { // p1 = routes[i][j]; // tr[p1].push_back(std::make_pair(i, (j+1)%n)); // // for(int k = j+1; k < n; k++) { // // p2 = routes[i][k]; // // tr[p1].push_back(std::make_pair(i, k)); // // tr[p2].push_back(std::make_pair(i, j )); // // } // if(routes[i][j] == source) { // sourceCOL.push_back({i, j}); // } // } // } // for(int i = 0; i < sourceCOL.size(); i++) { // dfs(routes, source, target, sourceCOL[0].first, sourceCOL[0].second); // } for(int ij = 0; ij < sC.size(); ij++) { vector<int> dis(routes.size()+1, INT_MAX); vector<bool> status(routes.size()+1, false); dis[sC[ij]] = 0; queue<vector<int>> qe; qe.push({0, sC[ij]}); int distance, next, start, i, j, d, mem; vector<int> tp; while(!qe.empty()) { tp = qe.front(); distance = tp[0]; start = tp[1]; qe.pop(); if(status[start] == true) continue; status[start] = true; for(int k = 0; k < trr[start].size(); k++) { next = trr[start][k]; if(status[next] == false && dis[next] > distance + 1) { qe.push({distance + 1, next}); dis[next] = distance + 1; } } } int jmi = INT_MAX; for(int j = 0; j < ttCC.size(); j++) { if(dis[ttCC[j]] != INT_MAX) { jmi = min(jmi, dis[ttCC[j]]); } } minmin = min(jmi, minmin); } if(minmin == INT_MAX) return -1; return minmin + 1; } };
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/17 7:55:01

《创业之路》-769-CTO如何在如下六个维度进行能力的提升: 技术架构 | 技术战略 | 团队管理 | 商业与产品 | 创新与未来 | 高层思维

要成为一名卓越的 CTO&#xff08;首席技术官&#xff09;&#xff0c;不能只是“最大的程序员”&#xff0c;而必须是技术、组织、商业与战略的整合者。以下是围绕你提出的六大核心维度&#xff0c;系统化的能力提升路径与具体行动建议&#xff1a;&#x1f527; 一、产品与研…

作者头像 李华
网站建设 2026/4/11 19:24:08

无侵入式HyperWorks许可证使用数据采集方案

无侵入式HyperWorks许可证使用数据采集方案&#xff1a;企业如何有效提升性能与降低成本 作为一名IT部门经理&#xff0c;我深知企业在使用HyperWorks这类高性能仿真软件时&#xff0c;常常会面临一个长期存在的痛点&#xff1a;许可证资源有限&#xff0c;影响项目进度与效率…

作者头像 李华
网站建设 2026/4/16 16:05:28

C++中mutable关键字详解

1 mutable 是什么&#xff1f;一句话定义mutable 允许在 const 成员函数中修改某个类成员变量。mutable int cache_;它打破的是 bitwise const&#xff0c;而不是 logical const。2 C 中两种“常量性” 2.1 位级常量性&#xff08;bitwise const&#xff09; void foo(const A&…

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

收藏必备!大模型推理利器Chain-of-Thought技术详解

随着大语言模型&#xff08;LLM&#xff09;在复杂推理任务中的应用不断拓展&#xff0c;单纯让模型直接输出答案常常达不到我们想要的效果。Chain-of-Thought&#xff08;简称 COT&#xff09;技术通过引导模型一步步“思考”&#xff0c;显著提升了推理准确率和透明度。 带着…

作者头像 李华
网站建设 2026/4/15 18:34:34

【Java毕设源码分享】基于springboot+java个性化智能学习系统的设计与实现(程序+文档+代码讲解+一条龙定制)

博主介绍&#xff1a;✌️码农一枚 &#xff0c;专注于大学生项目实战开发、讲解和毕业&#x1f6a2;文撰写修改等。全栈领域优质创作者&#xff0c;博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java、小程序技术领域和毕业项目实战 ✌️技术范围&#xff1a;&am…

作者头像 李华
网站建设 2026/4/15 16:47:50

python基于GIS的旅游信息管理系统设计与实现_django Flask vue pycharm项目

目录已开发项目效果实现截图关于博主开发技术路线相关技术介绍核心代码参考示例结论源码lw获取/同行可拿货,招校园代理 &#xff1a;文章底部获取博主联系方式&#xff01;已开发项目效果实现截图 同行可拿货,招校园代理 ,本人源头供货商 python基于GIS的旅游信息管理系统设计…

作者头像 李华