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 & ...
随机推荐
- vs2013中opencv的配置
下面开始介绍如何配置,我用的系统是win8.1 64位系统,vs用的是vs3013 ultimate,先到官网下载opencv 我用的的版本是最新的版本3.0 ALPHA,下载下来直接执行即可,实际上 ...
- c++中如何查看一个类的内存布局
打开VS command prompt,输入下述命令可以看到对象的内存布局. cl a.cpp -d1 reportSingleClassLayout[classname] // reportSin ...
- 【v2.x OGE教程 11】 动画编辑器帮助文档
] 动画编辑器帮助文档 版本号 日期 作者 说明 1.0 2014-9-3 橙子游戏 文档创建 一.简单介绍 动画编辑器用于游戏动画的可视化编辑,支持序列帧动画和关键帧动画.通过解析生成的 ...
- 【iOS开发-80】Quartz2D绘图简介:直线/圆形/椭圆/方形以及上下文栈管理CGContextSaveGState/CGContextRestoreGState
本文转载至 http://blog.csdn.net/weisubao/article/details/41282457 - (void)drawRect:(CGRect)rect { //获得当前上 ...
- Java中List.remove报UnsupportedOperationException异常
今天项目中有个需求场景: A和B都是List,而B是A的子集,现在想求A和B的差集. 想到了List中提供的removeAll()方法可以求得差集,但是结果确报了UnsupportedOperatio ...
- SpringMVC spring-servlet.xml配置
<?xml version="1.0" encoding="UTF-8"?><beans xmlns="http://www.spr ...
- java高级主题
1 java.util.concurrent.locks.LockSupport park:阻塞线程. unpark:解除阻塞线程. 线程阻塞最基础的组件. 2 sun.misc.Unsafe 可以用 ...
- python 捕获异常详细信息
import os import sys import traceback BasePath = os.path.dirname(os.getcwd()) sys.path.append(BasePa ...
- 【网络与系统安全】20179209 wireshark和nmap实验
TCP三次握手包 在进行实验前,先梳理一遍TCP三次握手的过程,这个图是我本科学网络时画过不少于十遍的图,我觉得非常有纪念意义. 稍作解释,第一次握手,客户端发起请求连接,发送一个标志位为SYN的ip ...
- can t connect to mysql server on 'localhost'解决方法
源:http://www.111cn.net/database/mysql/37700.htm 先重启服务器可解决大部分问题 错误编号:2003 问题分析: 无法连接到 mysql 服务器,可能的情况 ...