hdu 1874(Dijkstra + Floyd)

链接:http://acm.hdu.edu.cn/showproblem.php?pid=1874

畅通工程续

Time Limit: 3000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)
Total Submission(s): 27692    Accepted Submission(s): 10019


Problem Description
某省自从实行了很多年的畅通工程计划后,终于修建了很多路。不过路多了也不好,每次要从一个城镇到另一个城镇时,都有许多种道路方案可以选择,而某些方案要比另一些方案行走的距离要短很多。这让行人很困扰。

现在,已知起点和终点,请你计算出要从起点到终点,最短需要行走多少距离。

 

Input
本题目包含多组数据,请处理到文件结束。
每组数据第一行包含两个正整数N和M(0<N<200,0<M<1000),分别代表现有城镇的数目和已修建的道路的数目。城镇分别以0~N-1编号。
接下来是M行道路信息。每一行有三个整数A,B,X(0<=A,B<N,A!=B,0<X<10000),表示城镇A和城镇B之间有一条长度为X的双向道路。
再接下一行有两个整数S,T(0<=S,T<N),分别代表起点和终点。

 

Output
对于每组数据,请在一行里输出最短需要行走的距离。如果不存在从S到T的路线,就输出-1.

 

Sample Input
3 3
0 1 1
0 2 3
1 2 1
0 2
3 1
0 1 1
1 2

 

Sample Output
2
-1
【】【】【】【】【】【】【】【】【】【】【】【】【】【】【】【】【】【】
经典最短路,但是有坑。。。。。
第一:起点与终点可能会相同
第二:两条路之间可能会有不止一条道路
第三:起点给了,要注意Dijk赋初值

缺一则WA

Dijkstra:

#include <stdio.h>
#include <string.h>
#include <stdlib.h>
#include <iostream>
#include <algorithm>
#include <map>#define INF 1000000000
#define MAXX 210
int mp[MAXX][MAXX];
int visit[MAXX],d[MAXX];void Dijkstra(int st,int n)
{int i,j,y;memset(visit,0,sizeof(visit));for(int i=0;i<n;i++){d[i]=mp[st][i];}d[st]=0;for(int i=0;i<n;i++){int m=INF,x=1;for(y=0;y<n;y++){if(!visit[y] && d[y]<=m){m = d[x = y];}}visit[x]=1;for(y=0; y<n; y++){if(!visit[y] && d[y]>d[x]+mp[x][y]){d[y]=d[x]+mp[x][y];}}}
}int main()
{int n,m,i,j;while(scanf("%d%d",&n,&m)!=EOF){for(i=0; i<MAXX; i++)for(j=0; j<MAXX; j++)mp[i][j]=INF;int a,b,c,st,ed;for(i=0; i<m; i++){scanf("%d%d%d",&a,&b,&c);mp[a][b]=mp[a][b]>c?c:mp[a][b];mp[b][a]=mp[a][b];}scanf("%d%d",&st,&ed);if(st == ed){printf("0\n");continue;}Dijkstra(st,n);if(d[ed] == INF){printf("-1\n");}else{printf("%d\n",d[ed]);}}return 0;
}
View Code

 

Floyd:

#include <stdio.h>
#include <string.h>
#include <stdlib.h>
#include <iostream>
#include <algorithm>#define MAXX 210
#define INF 1000000000int d[MAXX][MAXX];void Floyd(int n)
{int i,j,k;for(k=0; k<n; k++)for(i=0; i<n; i++)for(j=0; j<n; j++)if(d[i][k] + d[k][j] < d[i][j])d[i][j] = d[i][k] + d[k][j];
}int main()
{int n,m,i,j;//freopen("in.txt","r",stdin);while(scanf("%d%d",&n,&m)!=EOF){for(i=0; i<MAXX; i++)for(j=0; j<MAXX; j++)d[i][j] = INF;int a,b,c;for(i=0; i<m; i++){scanf("%d%d%d",&a,&b,&c);d[a][b] = d[a][b] > c ? c : d[a][b];d[b][a] = d[a][b];}int st,ed;scanf("%d%d",&st,&ed);if(st == ed){printf("0\n");continue;}Floyd(n);if(d[st][ed] == INF)printf("-1\n");elseprintf("%d\n",d[st][ed]);}return 0;
}
View Code

 

 

 

 

转载于:https://www.cnblogs.com/ccccnzb/p/3890962.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/432402.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Web 开发中很实用的10个效果【附源码下载】

在工作中&#xff0c;我们可能会用到各种交互效果。而这些效果在平常翻看文章的时候碰到很多&#xff0c;但是一时半会又想不起来在哪&#xff0c;所以养成知识整理的习惯是很有必要的。这篇文章给大家推荐10个在 Web 开发中很有用的效果&#xff0c;记得收藏&#xff01; 超炫…

蓝图中实现人物移动2

从Pawn继承一个蓝图类并编写下面代码&#xff0c;并添加摄像机组件 1. 实现前后移动2. 实现左右移动3. 实现鼠标移动方向4. 实现鼠标俯仰

实现两个pawn的切换

在playercontroller里面编写下面代码并把两个pawn放置到场景中

steam程序员php玩的游戏,Steam:又一款烧脑的编程游戏上线,宅男回家了也要开心加班!...

原标题&#xff1a;Steam&#xff1a;又一款烧脑的编程游戏上线&#xff0c;宅男回家了也要开心加班&#xff01;要是小伙伴们喜欢什么解谜、编程类游戏&#xff0c;相信Steam上的《程序员升职记》应该都是绿了的游戏&#xff0c;这款给宅男们设计智力游戏能让你享受到从底层到…

spline 用法

控制actor在level中沿着一个spline path运动。 由finterp to 函数的输出数值来控制每一帧actor运动的距离。 从开始位置到spline path的终点的时间&#xff0c;是1/interp speed。假如我们控制actor从开头到终点运动的总时间是1秒&#xff0c;那么 interp speed就传入0.5&#…

HTML5 Canvas 高仿逼真 3D 布料图案效果

HTML5 规范引进了很多新特性&#xff0c;其中最令人期待的之一就是 Canvas 元素&#xff0c;HTML5 Canvas 提供了通过 JavaScript 绘制图形的方法&#xff0c;非常强大。下面给大家分享一个 HTML5 Canvas 绘制的 3D 布料图案效果。 温馨提示&#xff1a;为保证最佳的效果&#…

本地windows主机无法访问虚拟机里主机解决办法

一&#xff1a;设置虚拟机里IP&#xff0c;使其与本地计算机IP在同一网段 本地计算机网络IP设置如下&#xff1a; 虚拟机里ip为192.168.1.9 设置IP步骤请参考&#xff1a;Linux里如何设置IP(RED HAT) 二&#xff1a;将虚拟机网络连接方式设为桥接 假如&#xff0c;VirtualBox不…

linux服务器3306端口,linux系统对外开放3306、8080等端口,防火墙设置详解

linux系统对外开放3306、8080等端口&#xff0c;防火墙设置详解发布时间&#xff1a;2020-10-10 23:08:49来源&#xff1a;脚本之家阅读&#xff1a;141作者&#xff1a;julielele栏目&#xff1a;服务器我们很多时候在liunx系统上安装了web服务应用后(如tomcat、apache等)&…

hdu--1231--并查集连分量的个数

我觉得 这题 是纯粹的 并查集 可以算成 入门题吧 问你有几章桌子 就是问你有几个 连通块嘛 一个道理 touch me 这题 我采用了下 father[x]开始 初始化为-1 1 #include <iostream>2 #include <cstring>3 using namespace std;4 5 const int size 1010;6 int fathe…

landscape 1

1. 创建出landscape的分层材质2. 把材质添加给landscape后&#xff0c;可以在landscape的画刷模式下看到3. 通过点击右侧的加号&#xff0c;依次添加layer后&#xff0c;就可以使用他们进行地形的绘制。 通过右键菜单可以快速填充和清除对应的layer4. 用下面的方法修改材质的法…

linux进程和线程教程,Linux下查看进程和线程

在Linux中查看线程数的三种方法1、top -H手册中说&#xff1a;-H : Threads toggle加上这个选项启动top&#xff0c;top一行显示一个线程。否则&#xff0c;它一行显示一个进程。2、ps xH手册中说&#xff1a;H Show threads as if they were processes这样可以查看所有存在的线…

ORA-12154: TNS: 无法解析指定的连接标识符

相信使用过Oracle数据库的人一定碰到过“ORA-12154: TNS: 无法解析指定的连接标识符”错误&#xff0c;我在此做一个小小的总结。在程序中连接Oracle数据库的方式与其他常用数据库&#xff0c;如&#xff1a;MySql,Sql Server不同&#xff0c;这些数据库可以通过直接指定IP的方…

Oracle的Net Configuration Assistant 配置

在进行团队开发的时候&#xff0c;一般团队的每一个人只需要安装一个客户端即可&#xff0c;没有必要安装一个Oracle 数据库服务器&#xff0c;而数据库服务器是属于共享的&#xff0c;此时&#xff0c;我们就需要配置客户端。客户端的配置可以有以下两种方式&#xff1a;第一种…

windows下hadoop的单机伪分布式部署(3)

下面介绍myeclipse与hadoop的集成。 我用的myeclipse版本是8.5. 1、安装hadoop开发插件 在hadoop1.2.1版本的安装包contrib/目录下&#xff0c;已经不再提供hadoop-eclipse-pligin-1.2.1.jar; 而是提供了源代码文件&#xff0c;需要我们自行重新编译成jar包文件&#xff1b;这里…

使用DBCA创建数据库

&#xff08;1&#xff09;选择“开始”—>“程序”—>Oracle-Oracle10g_home1—>配置和移植工具—>Database Configuration Assistant命令&#xff0c;启动DBCA&#xff0c;出现“欢迎使用”窗口&#xff0c;如图1&#xff1a;图1 &#xff08;2&#xff09;单击“…

linux-2.6.32.2内核在mini2440上的移植,Linux2.6.32.2移植到Mini2440

1.移植内核的准备工作(1)使用的环境操作系统&#xff1a;Fedora 10交叉编译工具使用&#xff1a;arm-linux-gcc-4.3.2(2)获取内核有很多方式可以获取 Linux 内核源代码,如果你的 Fedora10 平台可以上互联网,可以直接在命令行输入以下命令获取到最原汁原味的 Linux-2.6.32.2:#wg…

SliceProceduralMesh的使用

1. 构建一个actor&#xff0c;里面添加一个被切割的static mesh&#xff0c;比如一个立方体&#xff0c;再添加一个proceduralmesh。 然后在构造函数里面添加下面代码&#xff0c;将static mesh拷贝到proceduralmesh里。 另外将static mesh的hidden in game属性加上&#xff0c…

linux parallel 命令,Linux 并行处理神器 GNU Parallel 简明教程

Bash命令通常单线程运行&#xff0c;这意味着所有的处理工作只在单个 CPU 上执行。随着 CPU 规模的扩大以及核心数目的增加&#xff0c;这意味着只有一小部分的 CPU 资源用于处理任务&#xff0c;这样就造成了很大的资源浪费。 这种情况在进行多媒体转换(比如&#xff1a;图片和…

鼠标

1. 在UE4窗口中显示或隐藏鼠标2. 默认状态下&#xff0c;鼠标移动会转动摄像机&#xff0c;调用下面这个函数后&#xff0c;只有鼠标左键按下并移动才可以移动摄像机&#xff0c; 这样就可以对UMG这样的菜单进行控制

UMG

1. 2D UMG2. 3D UMG 新建一个Actor&#xff0c;添加一个widget组件进去&#xff0c;设置其widget class即可3. pawn和3D UMG的交互 在pawn里面加一个widgetinteraction组件&#xff0c;设置交互距离和形态&#xff0c;然后使用press pointer key就可以给3DUMG设置鼠标 点击事件…