社区讨论

邻接表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 条回复,欢迎继续交流。

正在加载回复...