当前位置: 首页 > 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.gsyq.cn/news/180865.html

相关文章:

  • 8个降AI率工具推荐,研究生必备避坑指南
  • Web编辑器复制PPT图片并自动上传服务器组件
  • 2025年靠谱的元宝搜索推广源头公司、诚信的千问搜索推广网络公司排行榜 - 工业推荐榜
  • CMS系统Word文档导入带公式解析的编辑器插件
  • 2025年北京沥青混凝土摊铺公司排行榜,新测评精选服务商推荐 - 工业品网
  • 2025小红书账号运营/1688运营/新媒体运营培训TOP5权威推荐 - mypinpai
  • 基于一键化部署、标准化与闭环式的运营商数据安全管理方案
  • 2025最新!9款AI论文平台测评:本科生写论文还能这么快?
  • 2025有实力的管道预制生产线公司TOP5权威推荐:行业知名度高的厂家深度测评 - 工业设备
  • find命令高级用法:批量文件操作的神器
  • 2025年北京热门市政工程服务公司推荐:北京屈氏伟业市政工程造价合理吗? - myqiye
  • 盒马鲜生礼品卡回收正规平台,回收一般几折 - 京回收小程序
  • 2025年福州西点咖啡培训学校年度排名:欧米奇满意度怎么样 - 工业品网
  • 2025宁波擅长婚姻家事的律师TOP5推荐:婚姻问题律师哪里找? - mypinpai
  • Java SpringBoot+Vue3+MyBatis 图书馆管理系统系统源码|前后端分离+MySQL数据库
  • Java SpringBoot+Vue3+MyBatis 网上商品订单转手系统系统源码|前后端分离+MySQL数据库
  • AI写论文哪个软件最好?不吹不黑,一次性给你说清楚!
  • 文献综述不是“拼贴术”!这款工具让综述自己“长”出逻辑骨架——宏智树AI实测揭秘
  • GitHub Discussions社区问答:Miniconda-Python3.9镜像使用交流
  • 2025年服务不错的主播培训企业推荐:主播培训专业机构、主播培训实力机构有哪些? - myqiye
  • 写论文软件哪个好?我用实测数据告诉你答案!
  • 打造班级成绩单多维度成绩分析智能体|基于扣子×TextIn大模型加速器×火山引擎实战构建
  • 无服务器架构(Serverless)测试策略
  • 重塑电力未来:新型电力系统赛道技术领先的公司有哪些?
  • 收藏必备:一文读懂AI Agent与工作流的本质区别,掌握大模型开发真谛
  • 2025年靠谱1688运营/小红书运营/淘宝运营培训头部品牌机构排行榜 - 工业设备
  • GitHub Gist代码片段分享:Miniconda-Python3.9镜像使用示例
  • 2025年不错的热拌沥青混凝土摊铺公司推荐,摊铺沥青混凝土推荐机构与公司全解析 - 工业品牌热点
  • GitHub 一周热门项目速览 | 2025年12月30日
  • Anaconda安装教程进阶篇:从Miniconda-Python3.9镜像理解底层原理