朴素版Dijkstra
从t出去所有的边,t所组成的路径能不能更新其他点的距离。
每一次迭代都可以确定一个点的最短距离(每次都找当前还没有确定的点中距离最小的一个点(最短距离指的是1号点到当前点的距离),那么这个点的距离一定是最短路,变为确认的点。确定这个点之后,用这个点去更新其他点的最短路。),循环n次,确定n个点的最短距离。
朴素板的Dijkstra由于边数很多,稠密图用邻接矩阵存。
此题允许存在重边和自环,如果存在多条边,保留距离最短的那条边。
#include<iostream>
#include<algorithm>
#include<cstring>
using namespace std;
const int N=510;
int g[N][N];//邻接矩阵
int dist[N];//到1点的距离
bool st[N];//点是否确定最短路
int n,m;
int dijkstra(){
memset(dist,0x3f,sizeof dist);//初始化为无穷大
dist[1]=0;//初始化1的距离是0
for(int i=0;i<n-1;i++){//只用找n-1个点
int t=-1;//t代表确定的点,初始化-1代表没有确定的点
for(int j=1;j<=n;j++){//点1到n
if(!st[j] && (t==-1||dist[t]>dist[j])){//如果没确定过,并且是第一次或有距离更近的点
t=j;
}
}
for(int j=1;j<=n;j++){//从这个确定点更新其他点的距离
dist[j]=min(dist[j],dist[t]+g[t][j]);
}
st[t]=true;
}
if(dist[n]==0x3f3f3f3f) return -1;//表示第n点不联通
return dist[n];
}
int main(){
cin>>n>>m;
memset(g,0x3f,sizeof g);
while(m--){
int a,b,c;
cin>>a>>b>>c;
g[a][b]=min(g[a][b],c);//重边取最短的
}
cout<<dijkstra()<<endl;
return 0;
}