AcWing 849. Dijkstra求最短路 I
原题链接
简单
作者:
english
,
2019-10-02 20:52:43
,
所有人可见
,
阅读 794
#include<bits/stdc++.h>
using namespace std;
int n,m;
const int N=600;
int g[N][N];
int dist[N];//1 号点到每个点的最短距离
bool st[N];//每个点是不是确定了最短距离
int dijkstra()
{
memset(dist,0x3f3f3f3f,sizeof dist);
dist[1]=0;
//不能写st[1]=true; 进入循环后悔出大问题
for(int i=1;i<=n;i++)
{
int t=-1;
for(int j=1;j<=n;j++)
{
if(!st[j]&&(t==-1||dist[t]>dist[j]))
{
t=j;
}
}
st[t]=true;
for(int j=1;j<=n;j++)
{
dist[j]=min(dist[j],dist[t]+g[t][j]);
}
}
if(dist[n]==0x3f3f3f3f) return -1;
return dist[n];
}
int main()
{
cin>>n>>m;
for(int i=1;i<=n;i++)
for(int j=1;j<=n;j++)
{
if(i==j)
{
g[i][j]=0;
}
else{
g[i][j]=0x3f3f3f3f;
}
}
while(m--)
{
int a,b,w;
cin>>a>>b>>w;
g[a][b]=min(g[a][b],w);
}
int t=dijkstra();
cout<<t;
return 0;
}