#include<iostream> #include<algorithm> #include<cstring> using namespace std; const int N=1e1+10; int n,m; int dis[N],g[N][N]; //dis存每个点到起点的最短距离 g存a到b的距离 bool st[N]; //判断该点是否已经是最短距离 int find() { memset(dis,0x3f,sizeof dis); dis[1]=0; //初始化所有点距离都为无穷 ,起点距离为0 for(int i=0;i<n;i++) //n个点循环n次 { int t=-1; for(int j=1;j<=n;j++) //每次找出还未确定点中最短的点 { if(!st[j]&&(t==-1||dis[t]>dis[j])) t=j; } for(int j=1;j<=n;j++) //更新所有点的距离 dis[j]=min(dis[j],dis[t]+g[t][j]); st[t]=true; } if(dis[n]==0x3f3f3f3f)return -1; return dis[n]; } int main(void) { cin>>n>>m; memset(g,0x3f,sizeof g); while(m--) { int a,b,x; cin>>a>>b>>x; g[a][b]=min(g[a][b],x); //保证a到b为最短,考虑a到b有多条边的情况 } int t=find(); cout<<t<<endl; return 0; }
0.0分
1 人评分
亲和的解法浏览:1102 |
C语言训练-求具有abcd=(ab+cd)2性质的四位数 (C语言代码)浏览:1392 |
破解简单密码 (C语言代码)浏览:1866 |
【绝对值排序】 (C语言代码)浏览:832 |
【数组的距离】 (C语言代码)浏览:787 |
C语言考试练习题_一元二次方程 (C语言代码)浏览:606 |
C语言程序设计教程(第三版)课后习题5.8 (C语言代码)浏览:1325 |
The 3n + 1 problem (C语言代码)浏览:550 |
简单的事情 (C语言代码)浏览:679 |
拆分位数 (C语言代码)浏览:558 |