代码拉取完成,页面将自动刷新
// Time: O(|V| + |E|)
// Space: O(|V| + |E|)
class Solution {
public:
int numBusesToDestination(vector<vector<int>>& routes, int S, int T) {
if (S == T) {
return 0;
}
unordered_map<int, unordered_set<int>> to_route;
for (int i = 0; i < routes.size(); ++i) {
for (const auto& stop : routes[i]) {
to_route[stop].emplace(i);
}
}
int result = 1;
vector<int> q{S};
unordered_set<int> lookup{S};
while (!q.empty()) {
vector<int> next_q;
for (const auto& stop : q) {
for (const auto& i : to_route[stop]) {
for (const auto& next_stop : routes[i]) {
if (lookup.count(next_stop)) {
continue;
}
if (next_stop == T) {
return result;
}
next_q.emplace_back(next_stop);
to_route[next_stop].erase(i);
lookup.emplace(next_stop);
}
}
}
swap(q, next_q);
++result;
}
return -1;
}
};
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。