HDU 2544 最短路(floyd+bellman-ford+spfa+dijkstra队列优化)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2544
题目大意:找点1到点n的最短路(无向图)
练一下最短路。。。
dijkstra+队列优化:
#include<iostream>
#include<functional>
#include<vector>
#include<queue>
using namespace std;
typedef pair<int, int> p;//first是最短距离,second是顶点编号
const int N = ;
const int INF = << ; struct edge {
int to, cost;//邻接的点,以及到该点的权值
}; vector<edge>eg[N];//邻接表
bool used[N];//表示是否已被使用过
int d[N];//最短距离
int V, E;//顶点数和边数 void dijistra(int s) {
//优先队列,按first从小到大顺序
priority_queue<p, vector<p>, greater<p> >q;
//初始化
for (int i = ; i <= V; i++) {
d[i] = INF;
used[i] = false;
}
d[s] = ; q.push(p(, s));
while (!q.empty()) {
p p1 = q.top();
q.pop();
int v = p1.second;
if (used[v]) continue;
used[v] = true;
for (int i = ; i<eg[v].size(); i++) {
edge e = eg[v][i];
if (d[e.to]>d[v] + e.cost) {
d[e.to] = d[v] + e.cost;
q.push(p(d[e.to], e.to));
}
}
}
} int main() {
while (cin >> V >> E && (V || E)) {
for(int i=;i<=V;i++){
eg[i].clear();
}
for (int i = ; i <= E; i++) {
int a, b, cost;
cin >> a >> b >> cost;
edge g1, g2;
g1.to = b, g2.to = a;
g1.cost = g2.cost = cost;
eg[a].push_back(g1);
eg[b].push_back(g2);
}
dijistra();
cout << d[V] << endl;
}
}
bellman-ford:
/*
bellman-ford
*/
#include<iostream>
#include<cstring>
using namespace std;
const int N=;
const int INF=<<; struct edge{
int from,to,cost;
}es[N];//边 int d[N];//出发点到i的最短距离
int V,E;//顶点数、边数 //求解从顶点s出发到所有点的最短距离
void shortest_path(int s){
for(int i=;i<=V;i++) d[i]=INF;
d[s]=;
while(true){
bool update=false;
for(int i=;i<=E;i++){
edge e=es[i];
if(d[e.from]!=INF&&d[e.to]>d[e.from]+e.cost){
d[e.to]=d[e.from]+e.cost;
update=true;
}
//双向
if(d[e.to]!=INF&&d[e.from]>d[e.to]+e.cost){
d[e.from]=d[e.to]+e.cost;
update=true;
} }
if(!update) break;
}
} int main(){
int n,m;
while(cin>>V>>E&&(V||E)){
for(int i=;i<=E;i++){
cin>>es[i].from>>es[i].to>>es[i].cost;
}
shortest_path();
cout<<d[V]<<endl;
}
}
floyd:
/*floyd*/
#include<iostream>
#include<algorithm>
using namespace std;
const int N=;
const int INF=<<;
int map[N][N];//map[i][j]表示边i~j的距离 int V,E;//顶点数,边数 void floyd(){
for(int k=;k<=V;k++)
for(int i=;i<=V;i++)
for(int j=;j<=V;j++)
map[i][j]=min(map[i][j],map[i][k]+map[k][j]);
} int main(){
while(cin>>V>>E&&(V||E)){
for(int i=;i<=V;i++){
for(int j=;j<=V;j++){
if(i==j)
map[i][j]=;
else
map[i][j]=INF;
}
}
for(int i=;i<=E;i++){
int a,b,cost;
cin>>a>>b>>cost;
map[a][b]=map[b][a]=cost;
}
floyd();
cout<<map[][V]<<endl;
}
}
spfa:
/*spfa*/
#include<iostream>
#include<queue>
#include<algorithm>
using namespace std;
const int N=;
const int INF=<<; int map[N][N];
int d[N];//距离起点最小距离
bool used[N];//点是否在队列中
int V,E;//顶点数,边数 //求解从顶点s出发到所有点的最短距离
void spfa(int s){
//初始化
for(int i=;i<=V;i++){
d[i]=INF;
used[i]=false;
}
d[s]=; queue<int>q;
q.push(s);
used[s]=true;
while(!q.empty()){
int k=q.front();
q.pop();
used[k]=false;
//此处实际上可以不用遍历所有点,能够用邻接表优化
for(int i=;i<=V;i++){
if(d[i]>d[k]+map[k][i]){
d[i]=d[k]+map[k][i];
//这个点更新后要入队,要判断是否已经在队列中
if(!used[i]){
q.push(i);
used[i]=true;
}
}
}
}
} int main(){
while(cin>>V>>E&&(V||E)){
//初始化
for(int i=;i<=V;i++)
for(int j=;j<=V;j++)
map[i][j]=(i==j?:INF); for(int i=;i<=E;i++){
int a,b,cost;
cin>>a>>b>>cost;
map[a][b]=map[b][a]=cost;
}
spfa();
cout<<d[V]<<endl;
}
}
HDU 2544 最短路(floyd+bellman-ford+spfa+dijkstra队列优化)的更多相关文章
- HDU 2544 最短路 (Floyd)
题意:略. 析:由于 n 比较小,所以我们可以用Floyd,完全不会超时. 代码如下: #pragma comment(linker, "/STACK:1024000000,10240000 ...
- UESTC 30 &&HDU 2544最短路【Floyd求解裸题】
最短路 Time Limit: 5000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total Submiss ...
- ACM: HDU 2544 最短路-Dijkstra算法
HDU 2544最短路 Time Limit:1000MS Memory Limit:32768KB 64bit IO Format:%I64d & %I64u Descrip ...
- HDU - 2544最短路 (dijkstra算法)
HDU - 2544最短路 Description 在每年的校赛里,所有进入决赛的同学都会获得一件很漂亮的t-shirt.但是每当我们的工作人员把上百件的衣服从商店运回到赛场的时候,却是非常累的!所以 ...
- 蓝桥杯 algo_5 最短路 (bellman,SPFA)
问题描述 给定一个n个顶点,m条边的有向图(其中某些边权可能为负,但保证没有负环).请你计算从1号点到其他点的最短路(顶点从1到n编号). 输入格式 第一行两个整数n, m. 接下来的m行,每行有三个 ...
- hdu 2544 最短路
题目连接 http://acm.hdu.edu.cn/showproblem.php?pid=2544 最短路 Description 在每年的校赛里,所有进入决赛的同学都会获得一件很漂亮的t-shi ...
- hdu 2544最短路——最短路的初次总结 UESTC 6th Programming Contest Online
这是一道标准的模板题,所以拿来作为这一段时间学习最短路的总结题目. 题意很简单: 有多组输入数据,每组的第一行为两个整数n, m.表示共有n个节点,m条边. 接下来有m行,每行三个整数a, b, c. ...
- (重刷)HDU 1874 畅通工程续 + HDU 2544 最短路 最短路水题,dijkstra解法。
floyd解法 今天初看dijkstra,先拿这两题练手,其他变形题还是不是很懂. 模版题,纯练打字... HDU 1874: #include <cstdio> #define MAXN ...
- HDU 2544最短路 (迪杰斯特拉算法)
传送门: http://acm.hdu.edu.cn/showproblem.php?pid=2544 最短路 Time Limit: 5000/1000 MS (Java/Others) Me ...
随机推荐
- 【省选水题集Day1】一起来AK水题吧! 题解(更新到B)
题目:http://www.cnblogs.com/ljc20020730/p/6937936.html 水题A:[AHOI2001]质数和分解 安徽省选OI原题!简单Dp. 一看就是完全背包求方案数 ...
- linux内核分析 第四周 扒开系统调用的三层皮(上)
一.用户态.内核态和中断处理过程 系统调用是用户通过库函数方式:库函数帮我们把系统调用封装起来. 内核态:高级别执行,可以使用特权指令,访问任意的物理地址. 用户态:低级别执行,代码范围受到限制. C ...
- Zend Hash table 详解--转
原文地址:http://www.phppan.com/2009/12/zend-hashtable/ 在PHP的Zend引擎中,有一个数据结构非常重要,它无处不在,是PHP数据存储的核心,各种常量.变 ...
- 洛谷P1943 LocalMaxima_NOI导刊2009提高(1)(分段打表)
显然只需要算出每个数比前面所有数大的期望然后全部加起来就好了,一个数的期望怎么算呢? 对于一个数我们需要考虑比它大的数,因为比它小的数放它前面放它后面都可以,但是比它大的数只能放它后面.考虑大于等于它 ...
- git使用经验(一)
在使用Git Push代码到数据仓库时,提示如下错误: [remote rejected] master -> master (branch is currently checked out) ...
- socketserver多线程处理
一.简介 SocketServer简化了网络服务器的编写.在进行socket创建时,使用SocketServer会大大减少创建的步骤,并且SocketServer使用了select它有5个类:Base ...
- 「Python」35个知识点
No.1 一切皆对象 众所周知,Java中强调“一切皆对象”,但是Python中的面向对象比Java更加彻底,因为Python中的类(class)也是对象,函数(function)也是对象,而且Pyt ...
- 用shell获取目录/文件夹/文件的时间戳
命令: date +%s -r 目录名/文件名 输出内容形如: 1276225332
- POJ 2318/2398 叉积性质
2318 2398 题意:给出n条线将一块区域分成n+1块空间,再给出m个点,询问这些点在哪个空间里. 思路:由于只要求相对位置关系,而对具体位置不关心,那么易使用叉积性质得到相对位置关系(左侧/右侧 ...
- form表单有条件的提交
form表单提交数据,比如,积分,score,在0--100之间 var score = $('#score').val(); if(score !=''){ if(isNaN(score)){ la ...