news 2026/6/10 18:11:35

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/5/25 9:46:00

Java Web 图书管理系统系统源码-SpringBoot2+Vue3+MyBatis-Plus+MySQL8.0【含文档】

摘要 随着信息技术的快速发展&#xff0c;图书馆管理系统逐渐从传统的手工管理模式向数字化、智能化方向转型。图书管理系统作为图书馆的核心业务支撑平台&#xff0c;其高效性和稳定性对图书馆的日常运营至关重要。传统的图书管理系统存在功能单一、扩展性差、用户体验不佳等问…

作者头像 李华
网站建设 2026/6/10 13:15:26

SpringBoot+Vue 停车场管理系统管理平台源码【适合毕设/课设/学习】Java+MySQL

摘要 随着城市化进程的加速和汽车保有量的快速增长&#xff0c;停车难问题日益突出&#xff0c;传统停车场管理方式效率低下、资源浪费严重。智能停车场管理系统通过信息化手段优化停车资源分配、提升管理效率成为解决这一问题的有效途径。该系统整合车辆识别、在线支付、数据统…

作者头像 李华
网站建设 2026/6/10 15:36:58

国内主流LIMS厂商选型指南

实验室就像企业的“检测中枢&#xff0c;以前靠纸笔记录、人工跑腿对接的传统模式&#xff0c;早就跟不上新时代“检测精准、服务高效、全程可溯”的核心需求了。想要突破瓶颈完成智能化转型&#xff0c;选对LIMS系统至关重要。而在国内主流LIMS厂商里&#xff0c;谁能真正适配…

作者头像 李华
网站建设 2026/6/10 14:06:28

最近在调试XY平台时发现,200Smart的脉冲输出功能配合威纶通触摸屏能玩出挺多花样。这次咱们直接上硬货,聊聊怎么用PLS指令实现不带加减速的平面插补

直线插补圆弧插补 Ver1.1.2 1.200smart 2.威纶通 3.pls指令编写&#xff0c;平面XY轴插补。 4.不带加减速先看硬件配置&#xff1a;200Smart的Q0.0和Q0.1分别接X/Y轴驱动器&#xff0c;威纶通MT8071IE做参数输入界面。关键点在于脉冲当量换算&#xff0c;假设丝杆导程5mm&#…

作者头像 李华