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 ...
随机推荐
- php 中date显示时间不对与Linux文件乱码问题
php 中date显示时间不对解决办法如下1.修改/etc/php.ini文件 在里头中找到data.timezone =去掉它前面的分号';' 然后设置data.timezone = “Asia/S ...
- 通过PyPI镜像安装Python包
有时,我们直接用pip install package_name安装包时,下载很慢,我们可以尝试从PyPI镜像下载包. 这里是镜像列表和目前的状态: http://www.pypi-mirrors.o ...
- webpack笔记二——entry
entry是输入目录文件,有三种形式 1.对象键值对形式 entry: { main: './src/script/main.js', b: './src/script/b.js' }, 注意的是输出 ...
- Java - Spring AOP 拦截器的基本实现
一个程序猿在梦中解决的 Bug 没有人是不做梦的,在所有梦的排行中,白日梦最令人伤感.不知道身为程序猿的大家,有没有睡了一觉,然后在梦中把睡之前代码中怎么也搞不定的 Bug 给解决的经历?反正我是有过 ...
- 007-spring cloud gateway-GatewayAutoConfiguration核心配置-RouteDefinition初始化加载
一.RouteDefinitionLocator 在Spring-Cloud-Gateway的GatewayAutoConfiguration初始化加载中会加载RouteDefinitionLocat ...
- iphone传照片还是用QQ比较好
之前设置相机格式为高效,通过用91助手的苹果助手导出来文件格式为HEIC,window下没法打开.网上介绍用微信传,发现传的是缩略图,不清楚.最后选择通过qq传比较高清.注意,如果从相册中进行选择的话 ...
- [LeetCode] All questions numbers conclusion 所有题目题号
Note: 后面数字n表明刷的第n + 1遍, 如果题目有**, 表明有待总结 Conclusion questions: [LeetCode] questions conclustion_BFS, ...
- 轮廓的查找、表达、绘制、特性及匹配(How to Use Contour? Find, Component, Construct, Features & Match)
http://www.cnblogs.com/xrwang/archive/2010/02/09/HowToUseContour.html 作者:王先荣 前言 轮廓是构成任何一个形状的边界或外形 ...
- Floyd 判圈算法
Floyd 判圈算法 摘自维基百科, LeetCode 上 141题 Linked List Cycle 用到这个, 觉得很有意思. 记录一下. 链接: https://zh.wikipedia.or ...
- boost--smart_ptr库
C++没有类似Java.C#等语言的垃圾回收机制,内存管理是最为头痛的工作. new.delete以及指针的不恰当运用是C++中造成资源获取/释放问题的根源. 智能指针是解决这些问题的一种方案,boo ...