因为数据比较小

所以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 畅通工程续(最短路训练的更多相关文章

  1. ACM: HDU 1874 畅通工程续-Dijkstra算法

    HDU 1874 畅通工程续 Time Limit:1000MS     Memory Limit:32768KB     64bit IO Format:%I64d & %I64u Desc ...

  2. HDU 1874 畅通工程续-- Dijkstra算法详解 单源点最短路问题

    参考 此题Dijkstra算法,一次AC.这个算法时间复杂度O(n2)附上该算法的演示图(来自维基百科): 附上:  迪科斯彻算法分解(优酷) problem link -> HDU 1874 ...

  3. hdu 1874 畅通工程续

    题目连接 http://acm.hdu.edu.cn/showproblem.php?pid=1874 畅通工程续 Description 某省自从实行了很多年的畅通工程计划后,终于修建了很多路.不过 ...

  4. HDU 1874畅通工程续(迪杰斯特拉算法)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1874 畅通工程续 Time Limit: 3000/1000 MS (Java/Others)     ...

  5. HDU 1874 畅通工程续(最短路/spfa Dijkstra 邻接矩阵+邻接表)

    题目链接: 传送门 畅通工程续 Time Limit: 1000MS     Memory Limit: 65536K Description 某省自从实行了很多年的畅通工程计划后,终于修建了很多路. ...

  6. HDU 1874 畅通工程续【Floyd算法实现】

    畅通工程续 Time Limit: 3000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total Submi ...

  7. hdu 1874 畅通工程续 Dijkstra

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1874 题目分析:输入起点和终点,顶点的个数,已连通的边. 输出起点到终点的最短路径,若不存在,输出-1 ...

  8. hdu 1874 畅通工程续(求最短距离,dijkstra,floyd)

    题目:http://acm.hdu.edu.cn/showproblem.php?pid=1874 /************************************************* ...

  9. hdu 1874 畅通工程续(迪杰斯特拉优先队列,floyd,spfa)

    畅通工程续 Time Limit: 3000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Total Subm ...

随机推荐

  1. 如何下载Bilibili视频

    方法1: https://www.bilibili.com/video/av25940642 (源网址) https://www.ibilibili.com/video/av25940642 (新网址 ...

  2. Centos7 中 Node.js安装简单方法

    最近,我一直对学习Node.js比较感兴趣.下面是小编给大家带来的Centos7 中 Node.js安装简单方法,在此记录一下,方便自己也方便大家,一起看看吧! 安装node.js 登陆Centos ...

  3. eclipse向svn提交代码的时候忽略部分资源配置

    eclipse向svn提交代码的时候有 .settings, .project, .classpath, target等不需要上传,所以在eclipse中配置一下就不会显示了,方法如下图:

  4. 关于 WebBrowser调用百度地图API 鼠标滚轮缩放地图级别失灵的解决办法

    在桌面程序下 百度地图API的鼠标缩放地图功能可能会失灵无效! 这个原因不是API的问题 小弟试了下在WEB上面是没有问题的 于是考虑可能是WebBrowser的获取焦点问题,于是在主窗体 添加了一个 ...

  5. 《Enhanced LSTM for Natural Language Inference》(自然语言推理)

    解决的问题 自然语言推理,判断a是否可以推理出b.简单讲就是判断2个句子ab是否有相同的含义. 方法 我们的自然语言推理网络由以下部分组成:输入编码(Input Encoding ),局部推理模型(L ...

  6. php PDO遇到的坑

    <?php $dbConn = new PDO( "mysql:host=localhost;dbname=adtuu",'root','root', array( // 强 ...

  7. uva11865 朱刘算法+二分

    这题说的需要最多花费cost元来搭建一个比赛网络,网络中有n台机器,编号为0 - n-1其中机器0 为服务器,给了n条线有向的和他们的花费以及带宽 计算,使得n台连接在一起,最大化网络中的最小带宽, ...

  8. Filter过滤器原理和登录实现

    Filter过滤器API      Servlet过滤器API包含了3个接口,它们都在javax.servlet包中,分别是Filter接口.FilterChain接口和FilterConfig接口. ...

  9. js如何模拟multipart/form-data类型的请求

    var temp = document.createElement('form'); temp.action = this.data.testURL; temp.method = 'post'; te ...

  10. Jquery 数组与字符串之间的转换

    var auth_list = []; $("input[name='auth_list']:checkbox").each(function () { if ($(this).a ...