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 ...
随机推荐
- javascript中的位运算,
罗浮宫群里又有讨论位运算符号|了,做过一段时间php,数据库保存布尔值数据经常用到,比如100110 就表明了六个属性的是与否,极大减少了数据量..] ECMAScript 中位运算跟其他语言一样的. ...
- git使用笔记(十四)cat-file
By francis_hao Mar 18,2018 git cat-file :提供仓库中对象实体的类型.大小和内容的信息 概要 git cat-file (-t | -s | -e | ...
- php求一维数组的排列
<?php class CombinationsGenerator { public function generate(array $list) { if (count($list) > ...
- char* & 与 char*
原文 char*& 为指针引用,通常需要更改指针本身并返回时才这样用. char *&是指针引用char *是指针当用指针引用作为形参的时候,改变形参的指针,同时实参的指针也改变了.当 ...
- Patch multi versions of windows via Power shell
Patch multi versions of windows via Power shell $version = Get-WmiObject -Class Win32_OperatingSyste ...
- spring整合hibernate时报错:org.hibernte.engine.transaction.spi.transactioncontext
错误提示:Caused by:java.lang.ClassNotFoundException: org.hibernte.engine.transaction.spi.transactioncont ...
- Spring整合JMS(二)——三种消息监听器(转)
*注:别人那复制来的 1.3 消息监听器MessageListener 在Spring整合JMS的应用中我们在定义消息监听器的时候一共可以定义三种类型的消息监听器,分别是MessageList ...
- 使用RVM轻松部署Ruby环境
Ruby用得不多,但发现有业务需要部署指定的版本和插件.起初找了一些Fedora的src.rpm重新打包,发现依赖问题比较多,最终还是费劲的把el6的包编出来了. 不巧今天又有业务要求el5的包,原本 ...
- Spark Core 资源调度与任务调度(standalone client 流程描述)
Spark Core 资源调度与任务调度(standalone client 流程描述) Spark集群启动: 集群启动后,Worker会向Master汇报资源情况(实际上将Worker的资 ...
- JAVA多线程提高九:Semaphere同步工具
java 中Semaphere可类比操作系统信号量,硬件资源如IO.内存.磁盘等都是有固定量的,多个程序需要竞争这些资源,没有资源就需要被挂起. 一.类和方法摘要 构造函数: public Semap ...