HDU2544最短路模板,
#include<iostream>
#include<stdio.h>
#include<stdlib.h>
#include<algorithm>
#include<vector>
#include<queue>
#include<string.h>
#include<stdlib.h>
using namespace std;
#define INF 0xfffffff
#define N 1010 int maps[N][N], dist[N];//distance保存表示从起点到i点的距离 maps保存图
bool visit[N];//标记这个店是否被参观过
int point, side;//点,边
void Init();
int Dij(int Star, int End);
int main()
{
while(cin >> point >> side, point + side)
{
Init();//Initial
int pa, pb, i, t;
for(i=0; i<side; i++)
{
cin >>pa>>pb>>t;
maps[pa][pb]=min(maps[pa][pb], t);//因为也许反向走路的长度不同
maps[pb][pa]=maps[pa][pb];
}
int answer=Dij(1, point);
cout << answer << endl;
}
return 0;
}
void Init()
{
for(int i=0; i<=point; i++)
{
visit[i]=false;
dist[i]=INF;
for(int j=0; j<=i; j++)//其实不明白这里为什么这样写,即便是我自己写的
maps[i][j]=maps[j][i]=INF;//真的很神奇,其实这就等同于for(int j=0; j<=point; j++) maps[i][j]=INF; }
}
int Dij(int Star, int End)
{
dist[Star]=0;
for(int i=1; i<=point; i++)
{
int index, Min;
index=0, Min=INF;//index 代表与i距点最近的点的下标
for(int j=1; j<=point; j++)
{
if(!visit[j]&&Min>dist[j])
Min=dist[j], index=j;
}//代表找到了距1点最近的一个点 这是一个二维矩阵
visit[index]=true;
for(int j=1; j<=point; j++)
{
if(!visit[j]&&dist[j]>dist[index]+maps[index][j])
dist[j]=dist[index]+maps[index][j];
}
}
return dist[End];
}
连接表代码
#include <iostream>
#include <cstdlib>
#include <cstdio>
#include <algorithm>
#include <vector>
#include <queue>
using namespace std;
#define INF 0xfffffff
#define maxn 1002
struct node
{
int e, w;
};
vector<node> G[maxn];
int dist[maxn];//表示从起点到第i点的距离
bool vis[maxn];//判断这个点是否被参观过
int m, n;//边数 m 顶点数 n void Init()
{
memset(vis, false, sizeof(vis)); for(int i=; i<=n; i++)
{
dist[i] = INF;
G[i].clear();
}
} int Dij(int Star,int End)//起点 --- 终点
{
dist[Star] = ;
for(int i=; i<=n; i++)
{
int index = , Min = INF;
for(int j=; j<=n; j++)
{
if( !vis[j] && Min > dist[j] )//找出没有被参观过,并且距离起点最近的点
Min = dist[j], index = j;
}
vis[index] = true;
int len = G[index].size();
for(int j=; j<len; j++)//更新所有未曾到达的点距离,使之成为最近的点
{
node P;
P = G[index][j]; if( !vis[P.e] && dist[P.e] > dist[index] + P.w )
{
dist[P.e] = dist[index] + P.w;
}
}
}
return dist[End];
} int main()
{
node P;
while(cin >> n >> m, m + n)
{
Init();
int a, b , c; for(int i=; i<m; i++)
{
cin >> a >> b >> c;
P.e = b, P.w = c;
G[a].push_back(P);
P.e = a;
G[b].push_back(P);
} int ans = Dij(,n);
cout << ans << endl;
}
return ;
}
HDU2544最短路模板,的更多相关文章
- POJ 2449Remmarguts' Date K短路模板 SPFA+A*
K短路模板,A*+SPFA求K短路.A*中h的求法为在反图中做SPFA,求出到T点的最短路,极为估价函数h(这里不再是估价,而是准确值),然后跑A*,从S点开始(此时为最短路),然后把与S点能达到的点 ...
- poj1511/zoj2008 Invitation Cards(最短路模板题)
转载请注明出处: http://www.cnblogs.com/fraud/ ——by fraud Invitation Cards Time Limit: 5 Seconds ...
- k短路模板 POJ2449
采用A*算法的k短路模板 #include <iostream> #include <cstdio> #include <cstring> #include < ...
- HDU 5521.Meeting 最短路模板题
Meeting Time Limit: 12000/6000 MS (Java/Others) Memory Limit: 262144/262144 K (Java/Others)Total ...
- ACM-ICPC 2018 沈阳赛区网络预赛 D. Made In Heaven(第k短路模板)
求第k短路模板 先逆向求每个点到终点的距离,再用dij算法,不会超时(虽然还没搞明白为啥... #include<iostream> #include<cstdio> #inc ...
- [poj2449]Remmarguts' Date(K短路模板题,A*算法)
解题关键:k短路模板题,A*算法解决. #include<cstdio> #include<cstring> #include<algorithm> #includ ...
- 51nod_1445 变色DNA 最短路模板 奇妙思维
这是一道最短路模板题,但是在理解题意和提出模型的阶段比较考验思维,很容易想到并且深深进入暴力拆解题目的无底洞当中. 题意是说:给出一个邻接矩阵,在每个点时,走且仅走向,合法路径中编号最小的点.问题是是 ...
- [hdu2544]最短路spfa
解题关键:最短路模板一直没整理过,这里整理了一下spfa+链式前向星建图的最短路模板,以后网络赛省的打了. spfa算法的关键就是松弛操作,只有进行松弛操作,其后的点距离才可能被更新. #includ ...
- poj 2499第K短路模板
第k*短路模板(单项边) #include <iostream> #include <cstdio> #include <algorithm> #include & ...
随机推荐
- Linux下, Eclipse C/C++ IDE下编辑好C/C++源程序之后要先保存!!!否则,就会……
注意:Linux下, Eclipse C/C++ IDE下编辑好C/C++源程序之后要先保存! ! ! 然后Project-->Build All/Build Project,再点绿箭头执行.否 ...
- 软件project--谈项目开发
前段时间一直忙自考.着急赶项目进度,如今最终有时间回想这段时间的学习,突然发现自己已有半个月没有沉淀. 今天早上醒来.灵感如泉水般涌出,挡都挡不住.所以早上一到机房,便迫不及待的想大家分享灵感,希望大 ...
- hdu 4454 Stealing a Cake(计算几何:最短距离、枚举/三分)
题意:已知起点.圆.矩形,要求计算从起点开始,经过圆(和圆上任一点接触即可),到达矩形的路径的最短距离.(可以穿过园). 分析:没什么好的方法,凭感觉圆上的每个点对应最短距离,应该是一个凸函数,用三分 ...
- lua学习笔记(九)
环境 全局变量table lua把所有的全局变量存在一个table里,并把这个table赋值给一个全局变量_G _G也在这个全局变量的table里,它就是一个普通 ...
- hdu 1010 Tempter of the Bone 奇偶剪枝
如果所给的时间(步数) t 小于最短步数path,那么一定走不到. 若满足t>path.但是如果能在恰好 t 步的时候,走到出口处.那么(t-path)必须是二的倍数. 关于第二种方案的解释 ...
- saltstack之用户管理
1.添加用户 /srv/salt/top.sls base: 'test82.salt.cn': - user.useradd /srv/salt/user/useradd.sls jim: user ...
- iOS开发之提交App中断出现:Cannot proceed with delivery: an existing transporter instance is currently uploading this package
iOS开发之提交App中断出现:Cannot proceed with delivery: an existing transporter instance is currently uploadin ...
- LNMP环境搭建(一:nginx)
1.从nginx官网获取源码包 # cd /usr/local/src # wget http://nginx.org/download/nginx-1.10.3.tar.gz 2.解压源码包 # t ...
- 【转】AC神组合数取模大全
貌似少了几张图片,不过没有图片也没什么关系的感觉. 最后的究极篇也想出来了,但是貌似找不到题目,好尴尬.. 这个表示的是从n个元素中选取m个元素的方案数. (PS.组合数求模似乎只用在信息学竞赛和 A ...
- Java获取字符串的CRC8校验码(由C程序的代码修改为了Java代码)
CRC8算法请百度,我也不懂,这里只是把自己运行成功的结构贴出来了.方法CRC8_Tab这里没有处理,因为我的程序中没有用到. package com.crc; public class CCRC8_ ...