//朴素Dijkstra 边权都是正数  稠密图:点和边差的比较多
#include<cstring>
#include<iostream>
#include<algorithm>
using namespace std;
const int N = ;
int n, m;
int g[N][N];//邻接矩阵 稠密图
int dist[N];//距离 从1到每个点的距离 当前的最短距离
bool st[N];
//每一次 找到当前没有确定最短路长度的点当中距离最小的那一个,
//然后用1到j的距离去和1到t的距离+t到h的距离比较,如果存在边,就会正常比较,如果不存在边,后者会变为正无穷
//相当于没比较
int dijkstra() {
memset(dist, 0x3f, sizeof dist);//先把所有的距离初始化为正无穷
dist[] = ;//把一号点初始化为0
for (int i = ; i < n - ; i ++ ) {//迭代n次
//每一次先找最小值 找到当前没有确定最短路长度的点当中距离最小的那一个
int t = -; //表示还没有确认1d
for (int j = ; j <= n; j ++ )//遍历所有点
//如果当前点还没有确定最短路,或者t还没有赋值,或者当前不是最短的
if (!st[j] && (t == - || dist[t] > dist[j]))//找还没有确定最短长度的点当中距离1最小的那一个
t = j;//遍历循环所有点,找到最小的
if(t==n) break;//说明1和n之间的边的权重最下
for (int j = ; j <= n; j ++ )
//用从1到t的距离加上t到j这条边来更新1到j这条边 每次都更新
dist[j] = min(dist[j], dist[t] + g[t][j]);
st[t] = true;
}
if (dist[n] == 0x3f3f3f3f) return -;//说明1和n不连通
return dist[n];//返回n的最短距离
}
int main() {
scanf("%d%d", &n, &m);
memset(g, 0x3f, sizeof g);//初始化
while (m -- ) {
int a, b, c;
scanf("%d%d%d", &a, &b, &c);
g[a][b] = min(g[a][b], c);//处理重边,保留长度最短的边 权重
}
printf("%d\n", dijkstra());
return ;
}

最新文章

  1. HttpClient 教程
  2. Oracle 执行计划(Explain Plan)
  3. 一起来开发Android的天气软件(三)——使用Volley实现网络通信
  4. mysql数据库表字段使用DESC等关键字报错及解决方法
  5. SQL Server The target database (&#39;db&#39;) is in an availability group and currently does not allow read only connections. For more information about application intent, see SQL Server Books Online.
  6. html-webpack-plugin插件使用
  7. 【python】web开发
  8. HDFS基础
  9. [UE4]从零开始构建VR角色
  10. 六、框架&lt;iframe&gt;、背景、实体
  11. How to translate virtual to physical addresses through /proc/pid/pagemap
  12. JVM总结(六):早期(编译期)优化
  13. openvSwitch tunnel
  14. Xshell 5 免费版本安装过程
  15. Linux系统下C语言程序的构建过程
  16. cocos2dx字体描边
  17. jquery优化轮播图2
  18. Google APAC----Africa 2010, Qualification Round(Problem B. Reverse Words)----Perl 解法
  19. C#求百分比
  20. PHP学习笔记之continue与break

热门文章

  1. 对one hot 编码的理解,sklearn. preprocessing.OneHotEncoder()如何进行fit()的?
  2. Android Studio阶段性学习总结_1
  3. 题解【AcWing95】费解的开关
  4. numpy学习(一)
  5. linux - python2.6.6 升级到python2.7.14
  6. 安卓开发中遇到java.net.SocketException: Permission denied
  7. &lt;软件工程基础&gt;个人项目——数独
  8. python Threading模块源码解析
  9. Appium连接模拟器
  10. DES加密算法 转