HDU 1874 畅通工程续(最短路训练
因为数据比较小
所以flyod spfa dijkstra 多可以过
Floyd
#include <bits/stdc++.h>
using namespace std;
const int INF = 0x3f3f3f3f;
const int maxn = ; int s[maxn][maxn];
int main (){
int n,m;
while(~scanf("%d %d",&n,&m) ){
for(int i=;i<n;i++){
for(int j=;j<n;j++){
if(i != j)
s[i][j] = INF;
else
s[i][j] = ;
}
}
for(int i=;i<m;i++){
int x,y,v; scanf("%d %d %d",&x,&y,&v);
s[x][y] = min(s[x][y],v);
s[y][x] = min(s[y][x],v);
}
for(int k=;k<n;k++)
for(int i=;i<n;i++)
for(int j=;j<n;j++)
s[i][j] = min(s[i][j],s[i][k]+s[k][j]);
int x,y;
scanf("%d %d",&x,&y);
if(s[x][y] == INF)
printf("-1\n");
else
printf("%d\n",s[x][y]);
}
}
spfa
// Spfa 算法 #include <bits/stdc++.h>
using namespace std;
const int maxn = ;
const int INF = 0x3f3f3f3f; vector <pair<int,int> >E[maxn];
int d[maxn],inq[maxn];//inq 代表的是是否in queue
int n,m;
void init(){
for(int i=;i<maxn;i++) d[i] = INF;
for(int i=;i<maxn;i++) inq[i] = ;
for(int i=;i<maxn;i++) E[i].clear();
}
int main()
{
while (~scanf("%d %d",&n,&m)){
init();
for(int i=;i<=m;i++){
int x,y,v;
scanf("%d %d %d",&x,&y,&v);
E[x].push_back(make_pair(y,v));
E[y].push_back(make_pair(x,v));
}
queue<int>Q;
int s,e;
scanf("%d %d",&s,&e);
d[s] = ;
inq[s] = ;//起点进队列
Q.push( s );
while (Q.size()){
int now = Q.front();
Q.pop(); inq[now] = ;//该点出队列
for(int i=;i < E[now].size();i++){
int y = E[now][i].first;
int v = E[now][i].second;
if(d[y] > d[now] + v )
{
d[y] = d[now] + v;
if( inq[y] )//如果在队列
continue;
inq[y] = ;
Q.push(y);
}
}
}
if(d[e] == INF)
printf("-1\n");
else
printf("%d\n",d[e]); }
return ;
}
dijkstra //待测试
#include <bits/stdc++.h>
using namespace std;
const int maxn = ;
const int INF = 0x3f3f3f3f;
int n,m;
vector<pair<int,int> > E[maxn];
int d[maxn];
void init(){
for(int i=;i<maxn;i++)
E[i].clear() ,d[i] = INF;
}
int main()
{
while (~scanf("%d %d",&n,&m)){
init();
for(int i=;i<=m;i++){
int x,y,v;
scanf("%d%d%d",&x,&y,&v);
E[x].push_back(make_pair(y,v));
E[y].push_back(make_pair(x,v));
}
int s,e;//start end;
scanf("%d %d",&s,&e);
d[s] = ;
int v = -;
priority_queue<pair<int,int> > Q;
Q.push(make_pair(-d[s],s));
while ( !Q.empty() )
{
int now = Q.top().second;
if( now == e)//相等就可以直接跳出了
break;
Q.pop();
for(int i=;i < E[now].size();i++)
{
v = E[now][i].first;
if(d[v] > d[now] + E[now][i].second )
{
d[v] = d[now] + E[now][i].second;
Q.push(make_pair(-d[v],v));
}
} }
if(d[e] == INF)
printf("-1\n");
else
printf("%d\n",d[e]);
}
return ;
}
HDU 1874 畅通工程续(最短路训练的更多相关文章
- ACM: HDU 1874 畅通工程续-Dijkstra算法
HDU 1874 畅通工程续 Time Limit:1000MS Memory Limit:32768KB 64bit IO Format:%I64d & %I64u Desc ...
- HDU 1874 畅通工程续-- Dijkstra算法详解 单源点最短路问题
参考 此题Dijkstra算法,一次AC.这个算法时间复杂度O(n2)附上该算法的演示图(来自维基百科): 附上: 迪科斯彻算法分解(优酷) problem link -> HDU 1874 ...
- hdu 1874 畅通工程续
题目连接 http://acm.hdu.edu.cn/showproblem.php?pid=1874 畅通工程续 Description 某省自从实行了很多年的畅通工程计划后,终于修建了很多路.不过 ...
- HDU 1874畅通工程续(迪杰斯特拉算法)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1874 畅通工程续 Time Limit: 3000/1000 MS (Java/Others) ...
- HDU 1874 畅通工程续(最短路/spfa Dijkstra 邻接矩阵+邻接表)
题目链接: 传送门 畅通工程续 Time Limit: 1000MS Memory Limit: 65536K Description 某省自从实行了很多年的畅通工程计划后,终于修建了很多路. ...
- HDU 1874 畅通工程续【Floyd算法实现】
畅通工程续 Time Limit: 3000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total Submi ...
- hdu 1874 畅通工程续 Dijkstra
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1874 题目分析:输入起点和终点,顶点的个数,已连通的边. 输出起点到终点的最短路径,若不存在,输出-1 ...
- hdu 1874 畅通工程续(求最短距离,dijkstra,floyd)
题目:http://acm.hdu.edu.cn/showproblem.php?pid=1874 /************************************************* ...
- hdu 1874 畅通工程续(迪杰斯特拉优先队列,floyd,spfa)
畅通工程续 Time Limit: 3000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Total Subm ...
随机推荐
- BUG笔记:Win8 IE10下input[type="password"]内字符显示被截取问题
这个BUG发生的截图: 这是发生在Windows8 IE10下,type为password的input文本框内输入长串字符后,初次失去焦点的时候会发生的一个BUG. 发生BUG的原因是这个文本框上应用 ...
- 测试Celery 在Windows中搭建和使用的版本
官网:http://docs.celeryproject.org/en/latest/faq.html#does-celery-support-windows 描述如下:表示Celery 4.0版本以 ...
- Scala系统学习(五):Scala访问修辞符
本章将介绍Scala访问修饰符.包,类或对象的成员可以使用私有(private)和受保护(protected)的访问修饰符进行标注,如果不使用这两个关键字的其中一个,那么访问将被视为公开(public ...
- django的分页器
Django中分页器的使用 django分页器模块 #分页器 from django.core.paginator import Paginator,EmptyPage,PageNotAnIntege ...
- Vim/Vi的使用
Vim 是vi的加强 Gvim图形化的vim Vim/Vi简介 Vim/Vi是一个功能强大的全屏幕文本编辑器,是Linux/Unix上最常用的文本编辑器,他们 的作用是建立,编辑,显示文本文件 Vi ...
- MatLab 2014a编译jar包时mcc无法使用的问题
http://blog.csdn.net/heroafei/article/details/43273373 MatLab 2014a编译jar包时mcc无法使用的问题 2015-01-29 16:5 ...
- Summary: sorting Algorithms
Insertion sort is a simple sorting algorithm that builds the final sorted array (or list) one item a ...
- 你真的了解[super ]关键字吗?
前言 此篇文章是看了阮老师的es6教程,看到super关键字的时候觉得有必要总结梳理一下,原文还是参考 ECMAScript 6入门. 正文 super 这个关键字,既可以当作函数使用,也可以当作对象 ...
- 7.MySQL必知必会之用通配符进行过滤-like
用通配符进行过滤-like 1. like操作符 先说两个概念:
- linux常用命令:telnet 命令
telnet命令通常用来远程登录.telnet程序是基于TELNET协议的远程登录客户端程序.Telnet协议是TCP/IP协议族中的一员,是Internet远程登陆服务的标准协议和主要方式.它为用户 ...