未优化dijkstra求助
查看原帖
未优化dijkstra求助
190931
cannotdp楼主2022/2/7 15:26
#include <iostream>
#include <cstring>
#include <algorithm>
using namespace std;
int a[9100][9100],d[30100],n,m;
bool v[30100];
void dijkstra(){
	memset(d,0x3f,sizeof(d));
	memset(v,0,sizeof(v));
	d[1]=0;
	for(int i=1;i<n;i++){
		int x=0;
		for(int j=1;j<=n;j++)
			if(!v[j]&&(x==0||d[j]<d[x])) x=j;
		v[x]=1;
		for(int y=1;y<=n;y++)
			d[y]=min(d[y],d[x]+a[x][y]);
	}
}
int main(){
	cin>>n>>m;
	memset(a,0x3f,sizeof(a));
	for(int i=1;i<=n;i++) a[i][i]=0;
	for(int i=1;i<=m;i++){
		int x,y,z;
		cin>>x>>y>>z;
		a[x][y]=min(a[x][y],z);
	//	a[x][y]=z;
	}
	dijkstra();
	for(int i=1;i<=n;i++)
		cout<<d[i]<<" ";
	return 0;
}

输出样例是这样的

2022/2/7 15:26
加载中...