【C++竞赛 E】xxx和yyy的旅行
时间限制:1s 内存限制:32MB
问题描述
有n个城市和m条双向铁路。对于任意两个不同的城市x和城市y,两个城市之间有双向铁路,否则有双向公路,通过任意一条直达公(铁)路花费一小时。城市x与城市y存在直达公(铁)路:乘坐汽(火)车可以从城市x到达城市y且中间不经过其它城市
一辆汽车和一辆火车停在城市1,它们有相同的目的地城市n。汽车只能走公路,火车只能走铁路。为了避免车祸的发生,汽车和火车不能在同一时间到达同一个城市(目的地城市n除外)。
现在xxx和yyy在城市1,他们想去城市n,xxx乘坐火车而yyy乘坐汽车。请你为他们规划路线,使得他们到达城市n所花费的时间T=max?(T_xxx,T_yyy)最小。
输入描述
第一行一个整数T(1≤T≤10)表示数据组数。
对于每组数据,第一行两个整数n(2≤n≤100),m(0≤m≤n(n-1)/2),接下来m行,每行两个整数u,v(1≤u,v≤n),表示城市u和城市v之间有一条双向铁路。
数据保证同一条铁路只会出现一次。
输出描述
对于每组数据,输出一行,如果xxx和yyy可以到达城市n,输出他们花费的最小时间,否则输出-1。
输入样例
1
4 3
1 3
1 4
2 4
输出样例
3
样例解释
样例如下图所示,其中铁路为实线,公路为虚线
xxx坐火车可从城市1直达城市4花费1小时
yyy坐汽车走1—2—3—4花费3小时
【题目链接】:
【题解】
铁路图上如果有从1-n的直接路径,就在公路图上做最短路;
否则在铁路图上做最短路;
因为有从1-n的直接路径的话,肯定走那条路最优;然后另外一个人怎么走都可以了;因为不会撞在一起(撞在n号节点是允许的);
【完整代码】
#include <bits/stdc++.h>
#define rep1(i,a,b) for (int i = a;i <= b;i++)
using namespace std;
#define pb push_back;
const int MAXN = 100+10;
const int INF = 0x3f3f3f3f;
bool bo[MAXN][MAXN];
vector <int> g[3][MAXN];
int dis[MAXN];
int main()
{
//freopen("F:\\rush.txt","r",stdin);
int T;
scanf("%d",&T);
while (T--)
{
memset(bo,false,sizeof(bo));
int n,m;
scanf("%d%d",&n,&m);
rep1(j,1,n)
g[1][j].clear(),g[2][j].clear();
rep1(i,1,m)
{
int x,y;
scanf("%d%d",&x,&y);
g[1][x].push_back(y);
g[1][y].push_back(x);
bo[x][y] = true;
bo[y][x] = true;
}
rep1(i,1,n)
rep1(j,1,n)
if (i!=j)
if (!bo[i][j])
g[2][i].push_back(j);
int t=1;
if (bo[1][n])
t = 2;
memset(dis,INF,sizeof(dis));
dis[1] = 0;
queue <int> dl;
dl.push(1);
while (!dl.empty())
{
int x = dl.front();
int len = g[t][x].size();
dl.pop();
rep1(i,0,len-1)
{
int y = g[t][x][i];
if (dis[y] > dis[x]+1)
{
dis[y] = dis[x]+1;
dl.push(y);
}
}
}
if (dis[n]>=INF)
puts("-1");
else
printf("%d\n",dis[n]);
}
return 0;
}
【C++竞赛 E】xxx和yyy的旅行的更多相关文章
- Aborted connection 1055898 to db: 'xxx' user: 'yyy' host: 'xxx.xxx.xxx.xxx' (Got timeout reading communication packets)
mysql错误日志中,发现大量以下类似信息:(mysql 5.7.18) [Note] Aborted connection 1055898 to db: 'xxx' user: 'yyy' host ...
- 【C++竞赛 F】yyy的三角形
时间限制:2s 内存限制:32MB 问题描述 yyy对三角形非常感兴趣,他有n个木棍,他正在用这些木棍组成三角形.这时xxx拿了两根木棍过来,xxx希望yyy能给他一根木棍,使得xxx可以组成一个三角 ...
- 旅行规划(travel)
题目描述 OIVillage 是一个风景秀美的乡村,为了更好的利用当地的旅游资源,吸引游客,推动经济发展,xkszltl 决定修建了一条铁路将当地 nnn 个最著名的经典连接起来,让游客可以通过火车从 ...
- vs2017下发现解决python运行出现‘No module named "XXX""的解决办法
对于使用vs2017开发python程序无疑发现,在解决方案资源管理器中设置把两个xxx.py,yyy.py文件都设置为启动文件,然后分别在vs2017这个IDE下运行这个两个文件在项目工程中运行,发 ...
- 点斜杠 & 如何查看linux程序安装位置 dpkg -L yyy
方法1: sudo find / -name ssh 方法2: Ubuntu下 看应用程序安装路径的方法 ubuntu下dpkg -L xxx看应用程序安装路径 1.点斜杠 “./”就代表在当前目录下 ...
- LG1337 [JSOI2004]平衡点 / 吊打XXX 模拟退火
问题描述 LG1337 题解 模拟退火模板 记住概率公式: \(exp(\frac{dealt}{T}) \times rand \ge R_A^ND^M_AX\) zzk太欧了,我交了一版没过他来了 ...
- bzoj3531——树链剖分+动态开点线段树
3531: [Sdoi2014]旅行 Time Limit: 20 Sec Memory Limit: 512 MB Description S国有N个城市,编号从1到N.城市间用N-1条双向道路连 ...
- Go语言的9大优势和3大缺点, GO语言最初的定位就是互联网时代的C语言, 我为什么放弃Go语言
Go语言的9大优势和3大缺点 转用一门新语言通常是一项大决策,尤其是当你的团队成员中只有一个使用过它时.今年 Stream 团队的主要编程语言从 Python 转向了 Go.本文解释了其背后的九大原因 ...
- XMU 1071 圣斗士黄金十二宫(七)银河星爆 【计算几何】
1071: 圣斗士黄金十二宫(七)银河星爆 Time Limit: 500 MS Memory Limit: 64 MBSubmit: 193 Solved: 10[Submit][Status] ...
随机推荐
- js08--函数1
函数当成类看当成匿名对象看,都是跟java吻合的,只有当成函数看(函数自己可以执行)跟java区别在这里. function fact(){} var F = fact ; 函数名是函数对象的地址,是 ...
- Java学习笔记六 常用API对象二
1.基本数据类型对象包装类:见下图 public class Test { public static void main(String[] args){ Demo(); toStringDemo() ...
- MariaDB 安装 (YUM)
在CentOS 7.0安装MariaDB的数据库,在这里记录下安装过程,以便以后查看. 1. 安装MariaDB 安装命令 yum -y install mariadb mariadb-server ...
- 分析器错误消息: 此实现不是 Windows 平台 FIPS 验证的加密算法的一部分
关于错误提示:此实现不是 Windows 平台 FIPS 验证的加密算法的一部分的解决方案 不知怎么的,每次Win10升级后相应的注册器都恢复默认了,当我运行08版的asp项目时会报这个错. vs上的 ...
- 将Maven的Java Project转换或修改为Web Project
将Maven的Java Project转换为Web Project关键是需要了解Eclipse和MyEclipse的工程中如下文件.classpath..project. .mymetadata和s ...
- 新版本的AutoCAD2018 怎样删除 A360 Drive盘符
通常的做法,如下: (1)点击开始菜单的“运行”(Win+R或者Win+X快捷选择运行),在弹出的对话框输入“regedit”,回车,进入注册表编辑器. (2)找到HKEY_LOCAL_MACHINE ...
- BAT面试题 - 找一个无序实数数组中的最大差值
题目描写叙述: 一个无序的实数数组a[i].要求求里面大小相邻的实数的差的最大值.比方 double a[]={1,5,4,0.2,100} 这个无序的数组,相邻的数的最大差值为100-5=95. 题 ...
- Javascript和jquery事件--鼠标滚轮事件WheelEvent
<1>js事件 滚轮事件在js中,不同浏览器还是有不同的,介于我只测试谷歌和火狐浏览器的情况,其他浏览器有待自行探索.有三种写法: target.onmousewheel = wheel; ...
- CentOS 6 通过DVD快速建立本地YUM源
一.将DVD光盘放入RedHat/CentOS6.X服务器/电脑光驱中 二.挂载DVD光驱到/mnt/cdrom # mkdir -p /mnt/cdrom # mount -t iso9660 /d ...
- Webpack学习手册
多端阅读<Webpack官方文档>: 在PC/MAC上查看:下载w3cschool客户端,进入客户端后通过搜索当前教程手册的名称并下载,就可以查看当前离线教程文档.下载Webpack官方文 ...