#include<bits/stdc++.h>
using namespace std;
const int maxn=1000+10;
const int INF=1000000000;
struct Edge{
int v,d;
Edge(int v,int d):v(v),d(d){}
bool operator<(const Edge&a)
const{return d>a.d;}
}; vector<Edge>Map[maxn];
int vis[maxn],dis[maxn];
void dijkstra(int n){
priority_queue<Edge>Q;
for(int i=1;i<=n;i++)dis[i]=INF; dis[1]=0;
Q.push(Edge(1,dis[1]));
while(!Q.empty()){
Edge now=Q.top();Q.pop();
if(vis[now.v])continue;
vis[now.v]=1;
printf("edge:%d\n",now.v);
for(int i=0;i<Map[now.v].size();i++){
Edge next=Map[now.v][i];
if(dis[next.v]>dis[now.v]+next.d){
dis[next.v]=dis[now.v]+next.d;
Q.push(Edge(next.v,dis[next.v]));
printf("%d %d\n",next.v,dis[next.v]);
}
}
}
}
int main(){
int n,m;
while(scanf("%d%d",&n,&m)==2 &&n){
for(int i=1;i<=n;i++)Map[i].clear();
memset(vis,0,sizeof(vis));
memset(dis,0,sizeof(dis));
while(m--){
int a,b,c;
scanf("%d%d%d",&a,&b,&c);
Map[a].push_back(Edge(b,c));
Map[b].push_back(Edge(a,c));
}
dijkstra(n);
for(int i=1;i<=n;i++)printf("%d ",dis[i]);
printf("\n");
}
return 0;
}
/*
5 7
1 2 2
1 3 1
1 4 6
2 4 1
3 4 4
3 5 10
4 5 1
*/

 

转载于:https://www.cnblogs.com/zhizhaozhuo/p/9594229.html

最新文章

  1. bootstrap学习笔记--bootstrap布局方式
  2. Java:IDEA下使用JUNIT
  3. HDU 1712 ACboy needs your help(分组背包)
  4. javascript生成对象的三种方法
  5. Javascript中DOM的练习
  6. jenkins自动部署maven工程到服务器----SSH+shell
  7. javascript拾掇
  8. linux下RTNETLINK answers: File exists的解决方案
  9. Maven实战(七)settings.xml相关配置
  10. wpf随笔
  11. Effective Java:Ch4_Class:Item13_最小化类及其成员的可访问性
  12. hdu4414(DFS 找十字架数量)
  13. hdu1686
  14. linux shell 推断文件或目录是否真的存在
  15. VUE请求本地数据的配置json-server
  16. Jmeter入门(01)Jmeter的下载和安装
  17. 深入理解android6.0 RunTime Permisstion
  18. Android为TV端助力:RecyclerView更新数据时焦点丢失
  19. 题解-CTSC2012 熟悉的文章
  20. 2110 ACM Crisis of HDU 母函数

热门文章

  1. preg_replace突然感觉好强大啊
  2. android开发对应高德地图定位服务进度一
  3. Python入门学习指导(VS Code配置向)
  4. SpringMVC框架详细教程(四)_使用maven导入各个版本的Spring依赖包
  5. JS 的事件基础、事件侦听与抛发、
  6. 百度AI开发平台简介
  7. work of 1/4/2016
  8. E - Farthest Nodes in a Tree
  9. Android内存优化—dumpsys meminfo详解
  10. timer和ScheduledThreadPoolExecutor定时任务和每日固定时间执行