news 2026/4/3 18:13:48

公交路线——全量遍历的路线BFS

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
公交路线——全量遍历的路线BFS

需要解决的问题是:给定多条公交路线(每条路线包含若干站点),以及起点和终点站点,求从起点到终点最少需要乘坐的公交线路数量(换乘次数 = 线路数 - 1)。

1.直接遍历站点会因站点数量庞大导致效率低下 2.需保证找到 “最少换乘” 的最优解,而非任意可行解。

代码采用广度优先搜索 而非站点级遍历,核心逻辑是:
将 “公交线路” 作为图的节点,“两条线路有公共站点” 作为节点间的边(可换乘);
从包含起点的所有线路出发,逐层遍历可换乘的线路;
一旦遍历到包含终点的线路,立即返回当前乘坐的线路数(保证最少);
全程记录路径,确保能追溯具体换乘顺序。

核心是把公交线路抽象为图的节点、线路间有公共站点抽象为可换乘的边,通过层序遍历保证找到最少换乘的最优解。代码首先初始化一个存储自定义QueueNode结构体的队列,结构体包含当前换乘路径(line_path)和已乘坐线路数(path_amount),同时用visited数组标记已入队的线路避免重复处理;接着将所有包含起点的线路作为 BFS 初始层入队,设置初始线路数为 1、路径仅含该线路。随后进入队列循环,每次取出队首节点,获取当前路径的最后一条线路,遍历所有未访问线路,通过has_common_stop判断是否可换乘,若可换乘则检查目标线路是否包含终点,若包含则拼接路径并返回当前线路数(即最少换乘对应的线路数);若未包含终点且线路数未超过限制,则复制当前路径、添加新线路、更新线路数后将新节点入队并标记为已访问。若队列遍历结束仍未找到终点,则返回 - 1 表示无可行路线,整个过程利用 BFS 逐层扩展的特性,确保第一次找到终点时的线路数即为最少乘车数,对应最少换乘次数。

queue<QueueNode> q;
vector<bool> visited(routes.size(), false);
for (int r_idx : start_routes) {
QueueNode node;
node.line_path.clear();
node.line_path.push_back(r_idx);
node.path_amount = 1;
q.push(node);
visited[r_idx] = true;
}

queue<QueueNode> q;

visited(routes.size(), false); QueueNode node; node.line_path.clear(); node.line_path.push_back(r_idx);

node.path_amount = 1;

q.push(node); // 节点入队 visited[r_idx] = true;

}

int result = -1;

while (!q.empty()) {

QueueNode cur = q.front(); q.pop();

int last_route = cur.line_path.back();

for (int i = 0; i < routes.size(); i++) { if (visited[i]) continue;

if (has_common_stop(routes[last_route], routes[i])) {

if (is_stop_in_route(T, routes[i])) {

line_path.clear(); for (int idx : cur.line_path) { line_path.push_back(idx + 1); } line_path.push_back(i + 1); result = cur.path_amount; return result; }

if (cur.path_amount + 1 < MAX_PATH) { QueueNode next_node; next_node.line_path = cur.line_path;

next_node.line_path.push_back(i);

next_node.path_amount = cur.path_amount + 1;

visited[i] = true;

q.push(next_node);

}

}

}

} return result;

本文解析的公交路线最短换乘代码,核心是将 “线路” 抽象为图节点、“换乘” 抽象为边,通过 BFS 的层序特性保证 “最少换乘” 的最优解。该方案兼顾了 “最优性” 和 “实用性”:
最优性:BFS 天然保证第一次找到终点时的换乘次数最少;
实用性:线路级遍历避免了站点级遍历的高复杂度,适配实际公交场景的规模。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/1 12:36:31

GraniStudio零代码平台如何创建多个视觉图像窗口?

GraniStudio零代码平台创建多个视觉图像窗口有以下步骤&#xff1a; 1.打开主任务设计器类&#xff0c;找到视图按钮 2.鼠标左键单击视图按钮&#xff0c;显示视图子菜单&#xff0c;鼠标左键单击图像窗口管理选项&#xff0c;窗口管理器窗口弹出 3.根据需要配置窗口名称&…

作者头像 李华
网站建设 2026/3/26 18:32:05

Android系统DMS驾驶纪录之GPS组件追踪服务架构分析

一、总体架构树形分析1.1 应用层架构逻辑树GpsTrackerService (主服务) ├── 通信管理层 │ ├── NettyControll (TCP长连接) │ ├── JMOrderControll (核心套件协议) │ └── SerialPortUtil (串口通信) ├── 位置处理层 │ ├── GpsControll (GPS数据采…

作者头像 李华
网站建设 2026/4/3 12:58:29

LobeChat新闻摘要生成服务搭建过程

LobeChat新闻摘要生成服务搭建过程 在信息爆炸的时代&#xff0c;每天面对成百上千条新闻推送&#xff0c;如何快速抓住重点、提炼核心内容&#xff0c;已成为媒体从业者、研究人员乃至普通用户的核心痛点。传统的关键词提取或自动摘要工具虽然能提供基础支持&#xff0c;但往…

作者头像 李华
网站建设 2026/3/27 9:05:31

线程及其函数

一&#xff0c;线程定义及特征1.概念&#xff1a;Linux中&#xff0c;线程是轻量级的进程&#xff0c;其属于某个进程。2.特征&#xff1a;进程是系统中最小的资源分配单位。线程是系统中最小的执行单位。进程中&#xff0c;线程与线程是平级关系。在进程中&#xff0c;默认有一…

作者头像 李华
网站建设 2026/4/1 21:43:30

双指针妙解:如何用最少的船救最多的人

求解思路 这道题的关键在于利用贪心策略: 让最轻的人和最重的人尝试配对。 我们先对所有人按体重排序,然后用两个指针分别指向最轻和最重的人。 如果这两个人的体重和不超过限制,说明他们可以共用一艘船,那就让他们一起走,两个指针同时向中间移动; 如果超过限制了,说明最重的人…

作者头像 李华
网站建设 2026/3/30 12:22:07

百川大模型+BGE嵌入+LobeChat组合拳实战

百川大模型 BGE嵌入 LobeChat&#xff1a;打造私有化智能对话系统的实战路径 在企业级AI应用日益普及的今天&#xff0c;一个核心挑战浮出水面&#xff1a;如何在保障数据安全的前提下&#xff0c;构建既智能又易用的本地化对话系统&#xff1f;许多团队曾尝试基于OpenAI搭建…

作者头像 李华