当前位置: 首页 > news >正文

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; } };
http://www.jsqmd.com/news/165359/

相关文章:

  • 三相分离器生产商哪家好:怎样选三相分离器制造商?年度排名推荐 - 工业设备
  • 矿石分析仪服务哪家好?手持矿石分析仪服务选哪家? - 工业推荐榜
  • 8个降AI率工具推荐,研究生必备避坑指南
  • 【日记】重庆半马组委会居然在物资里放油碟,这是人能想出来的方案吗……(1066 字)
  • 如何在CSDN创作一篇98分高质量的技术博客?
  • 2025年度河北环保设备企业口碑排名:三隆环保口碑如何? - 工业品牌热点
  • Web编辑器复制PPT图片并自动上传服务器组件
  • LeetCode215/347/295 堆相关理论与题目
  • CMS系统Word文档导入带公式解析的编辑器插件
  • 2025年靠谱的元宝搜索推广源头公司、诚信的千问搜索推广网络公司排行榜 - 工业推荐榜
  • Windows server 安装edb PostgreSQL无法访问
  • 2025年度洁净车间工程优质源头厂商权威推荐,洁净棚/货淋室/净化工程/风淋室/洁净车间工程/医疗装修工程洁净车间工程源头厂家推荐 - 品牌推荐师
  • 2025年北京沥青混凝土摊铺公司排行榜,新测评精选服务商推荐 - 工业品网
  • 基于一键化部署、标准化与闭环式的运营商数据安全管理方案
  • 2025小红书账号运营/1688运营/新媒体运营培训TOP5权威推荐 - mypinpai
  • 2025年欧米奇校区实力排名:欧米奇学历证书、全国分校及社会声誉深度解析 - 工业推荐榜
  • 2025年欧米奇校区实力排名:欧米奇学历证书、全国分校及社会声誉深度解析 - 工业推荐榜
  • 2025年座椅电梯厂推荐,座椅电梯品牌排名与专业厂家全解析 - mypinpai
  • 2025年座椅电梯厂推荐,座椅电梯品牌排名与专业厂家全解析 - mypinpai
  • 2025最新!9款AI论文平台测评:本科生写论文还能这么快?
  • 关闭 Edge/Chrome 浏览器不再支持Win7的提示
  • 2025有实力的管道预制生产线公司TOP5权威推荐:行业知名度高的厂家深度测评 - 工业设备
  • 2025有实力的管道预制生产线公司TOP5权威推荐:行业知名度高的厂家深度测评 - 工业设备
  • 2026年上海口碑屋顶防水服务商推荐:专业防水公司排名与源头优选 - shruisheng
  • 2025年北京热门市政工程服务公司推荐:北京屈氏伟业市政工程造价合理吗? - myqiye
  • find命令高级用法:批量文件操作的神器
  • find命令高级用法:批量文件操作的神器
  • 《创业之路》-769-CTO如何在如下六个维度进行能力的提升: 技术架构 | 技术战略 | 团队管理 | 商业与产品 | 创新与未来 | 高层思维
  • 盒马鲜生礼品卡回收正规平台,回收一般几折 - 京回收小程序
  • 盒马鲜生礼品卡回收正规平台,回收一般几折 - 京回收小程序