社区讨论
邻接表dij没判重边为什么能过
P6175无向图的最小环问题参与者 2已保存回复 2
讨论操作
快速查看讨论及其快照的属性,并进行相关操作。
- 当前回复
- 2 条
- 当前快照
- 1 份
- 快照标识符
- @ltgid6mq
- 此快照首次捕获于
- 2024/03/07 08:47 2 年前
- 此快照最后确认于
- 2024/03/07 16:08 2 年前
直接加进了邻接表,不用判重边吗?
CPP#include<bits/stdc++.h>
#define endl '\n'
using namespace std;
typedef long long ll;
const int N = 1e5;
vector<pair<int,int>>e [N];
bool vis[N];
int dis[N];
int ans = 1000005;
int n,m;
void init(){
for(int i = 1; i <= n; i++){
vis[i] = 0;
dis[i] = 1000005;
}
}
void dij(int r){
for(int j = 0; j < e[r].size(); j++){
init();
dis[r] = 0;
priority_queue<pair<int,int>, vector<pair<int,int>>, greater<pair<int,int>>>q;
q.push({0,r});
while(!q.empty()){
int u = q.top().second;
q.pop();
if(vis[u]) continue;
vis[u] = 1;
for(auto i : e[u]){
int v = i.first;
int w = i.second;
if(vis[v]) continue;
if(u == r && v == e[r][j].first) continue;
if(dis[v] > dis[u] + w){
dis[v] = dis[u] + w;
q.push({dis[v], v});
}
}
}
ans = min(ans, dis[e[r][j].first] + e[r][j].second);
}
}
int main(){
ios::sync_with_stdio(0);
cin.tie(0), cout.tie(0);
cin>>n>>m;
for(int i = 0; i < m; i++){
int u, v, d;
cin>>u>>v>>d;
if(u == v) continue;
e[u].push_back({v,d});
e[v].push_back({u,d}); //这里
}
for(int i = 1; i <= n; i++){
dij(i);
}
if(ans != 1000005) cout<<ans<<endl;
else cout<<"No solution."<<endl;
return 0;
}
回复
共 2 条回复,欢迎继续交流。
正在加载回复...