[洛谷P4436] HNOI/AHOI2018 游戏
问题描述
一次小G和小H在玩寻宝游戏,有n个房间排成一列,编号为1,2,...,n,相邻的房间之间都有一道门。其中一部分门上锁(因此需要有对应的钥匙才能开门),其余的门都能直接打开。现在小G告诉了小H每把锁的钥匙在哪个房间里(每把锁有且只有一把钥匙与之对应),并作出p次指示:第i次让小H从第\(S_i\)个房间出发到\(T_i\)个房间里。但是小G有时会故意在指令中放入死路,而小H也不想浪费多余的体力去尝试,于是想事先调查清楚每次的指令是否会存在一条通路。
你是否能为小H作出解答呢?
输入格式
第一行三个数字:n,m,p,代表有n个房间,m道门上了锁,以及p个询问。接下来m行,每行两个数字x,y代表x到x+1的钥匙在房间y。接下来p行,其中第i行是两个整数\(S_i,T_i\),代表一次询问。
输出格式
输出p行,每行一个“YES”或"NO",分别代表能或不能到达。
样例输入
5 4 5
1 3
2 2
3 1
4 4
2 5
3 5
4 5
2 1
3 1
样例输出
YES
NO
YES
YES
NO
说明

解析
可以发现对于每个点i,最后能到达的区域一定是一段区间[Li,Ri]。那么问题就是如何求这些区间。
如果一扇门的钥匙在这扇门的左边,那么就不能从右边穿过这扇门;如果在这扇门的右边,就不能从左边穿过去。那么,如果我们对每扇门的两边,由不能到达的向能到达的连边,可以发现一个点的区间范围一定可以由拓扑序在这个点前面的点得到(只有前面的点有边连向这个点)。所以,可以利用拓扑排序,对队首的点,向左向右扩展,扩展的点注意门的编号等于门右边的编号减一,具体见代码。
但是,对于一个可以互达的区间,有可能会连成一个环,这样拓扑排序就没有意义了。所以,最开始需要预处理能够互达的区间,并将这个区间缩成一个点。同时将所有信息更新成缩点之后的。
回答询问时,只需判断T是否在S的可达区间中即可。
代码
#include <iostream>
#include <cstdio>
#include <cstring>
#include <queue>
#define N 1000002
#define M 1000002
using namespace std;
int head[N],ver[M],nxt[M],d[N],t;
int n,m,q,i,x[N],y[N],pos[N],cnt=1,gap[N],l[N],r[N];
bool lock[N];
int read()
{
char c=getchar();
int w=0;
while(c<'0'||c>'9') c=getchar();
while(c<='9'&&c>='0'){
w=w*10+c-'0';
c=getchar();
}
return w;
}
void insert(int x,int y)
{
t++;
ver[t]=y;
nxt[t]=head[x];
head[x]=t;
d[y]++;
}
bool check(int x,int y)
{
if(y==0||y==cnt+1) return 0;
if(x<y) y--;
return l[x]<=pos[y]&&pos[y]<=r[x];//钥匙是否在当前可达区间中
}
void toposort()
{
queue<int> q;
for(int i=1;i<=cnt;i++){
if(d[i]==0) q.push(i);
}
while(!q.empty()){
int x=q.front();
q.pop();
bool flag=1;
while(flag){
flag=0;
while(check(x,l[x]-1)) l[x]=l[l[x]-1],flag=1;//可以就更新为左边的左端点
while(check(x,r[x]+1)) r[x]=r[r[x]+1],flag=1;//更新为右边的右端点
}
for(int i=head[x];i;i=nxt[i]){
int y=ver[i];
d[y]--;
if(d[y]==0) q.push(y);
}
}
}
int main()
{
n=read();m=read();q=read();
for(i=1;i<=m;i++){
x[i]=read();y[i]=read();
lock[x[i]]=1;
}
lock[n]=1;
for(i=1;i<=n;i++){
gap[i]=cnt;
if(lock[i]){
l[cnt]=r[cnt]=cnt;
cnt++;
}
}
cnt--;
for(i=1;i<=m;i++){
int tx=gap[x[i]],ty=gap[y[i]];
pos[tx]=ty;
if(ty<=tx) insert(tx+1,tx);
else insert(tx,tx+1);
}
toposort();
for(i=1;i<=q;i++){
int x=read(),y=read();
x=gap[x],y=gap[y];
if(l[x]<=y&&y<=r[x]) puts("YES");
else puts("NO");
}
return 0;
}
[洛谷P4436] HNOI/AHOI2018 游戏的更多相关文章
- [Bzoj5285][洛谷P4424][HNOI/AHOI2018]寻宝游戏(bitset)
P4424 [HNOI/AHOI2018]寻宝游戏 某大学每年都会有一次Mystery Hunt的活动,玩家需要根据设置的线索解谜,找到宝藏的位置,前一年获胜的队伍可以获得这一年出题的机会. 作为新生 ...
- 【题解】Luogu P4436 [HNOI/AHOI2018]游戏
原题传送门 \(n^2\)过百万在HNOI/AHOI2018中真的成功了qwqwq 先将没门分格的地方连起来,枚举每一个块,看向左向右最多能走多远,最坏复杂度\(O(n^2)\),但出题人竟然没卡(建 ...
- 洛谷P4424 [HNOI/AHOI2018]寻宝游戏(思维题)
题意 题目链接 Sol 神仙题Orz Orz zbq爆搜70.. 考虑"与"和"或"的性质 \(0 \& 0 = 0, 1 \& 0 = 0\) ...
- 洛谷P4438 [HNOI/AHOI2018]道路(dp)
题意 题目链接 Sol 每当出题人想起他出的HNOI 2018 Day2T3,他都会激动的拍打着轮椅 读题比做题用时长系列... \(f[i][a][b]\)表示从根到\(i\)的路径上,有\(a\) ...
- 洛谷P4425 [HNOI/AHOI2018]转盘(线段树)
题意 题目链接 Sol 首先猜一个结论:对于每次询问,枚举一个起点然后不断等到某个点出现时才走到下一个点一定是最优的. 证明不会,考场上拍了3w组没错应该就是对的吧... 首先把数组倍长一下方便枚举起 ...
- Luogu P4436 [HNOI/AHOI2018]游戏
题目 我们要求出\(l_i,r_i\)表示\(i\)最远能够到达的最左边和最右边的格子. 首先有一个比较简单的暴力,就是每次我们选择一个格子,然后从当前格子开始往左右暴力扩展,找到能够到达的最远的格子 ...
- 洛谷 P4437 [HNOI/AHOI2018]排列(贪心+堆,思维题)
题面传送门 开始 WA ycx 的遗产(bushi 首先可以将题目转化为图论模型:\(\forall i\) 连边 \(a_i\to i\),然后求图的一个拓扑序 \(b_1,b_2,\dots b_ ...
- 洛谷 P4426 - [HNOI/AHOI2018]毒瘤(虚树+dp)
题面传送门 神仙虚树题. 首先考虑最 trival 的情况:\(m=n-1\),也就是一棵树的情况.这个我相信刚学树形 \(dp\) 的都能够秒掉罢(确信).直接设 \(dp_{i,0/1}\) 在表 ...
- 洛谷P1118 数字三角形游戏
洛谷1118 数字三角形游戏 题目描述 有这么一个游戏: 写出一个1-N的排列a[i],然后每次将相邻两个数相加,构成新的序列,再对新序列进行这样的操作,显然每次构成的序列都比上一次的序列长度少1,直 ...
随机推荐
- WPF在资源内嵌入字体
比如需要有这种电子表的字体风格--这种样式叫 :longzhoufeng 字体 在微软的字体有 Quartz MS.TTF或者Quartz Regular.TTF字体.下面以Quartz Regula ...
- webpack中的 chunk,module,bundle的区别,以及hidden modules是什么
hidden modules是什么: chunk,module,bundle的区别 总结: module是指任意的文件模块,等价于commonjs中的模块 chunks是webpack处理过程中被分组 ...
- 阶段3 1.Mybatis_09.Mybatis的多表操作_2 完成account表的建立及实现单表查询
mybatis中的多表查询: 示例:用户和账户 一个用户可以有多个账户 一个账户只能属于一个用户(多个账户也可以属于同一个用户) ...
- 6.824 Lab 2: Raft 2B
Part 2B We want Raft to keep a consistent, replicated log of operations. A call to Start() at the le ...
- 关于win10系统如何调用debug查看CPU汇编指令和内存
下载安装DOSBox.网上提供下载地址:DOSBOX Debug是DOS(Disk Operating System,磁盘操作系统).windows提供的实模式(8086方式)程序的调试工具.使用它, ...
- 【HANA系列】SAP HANA STUDIO客户端升级更新
公众号:SAP Technical 本文作者:matinal 原文出处:http://www.cnblogs.com/SAPmatinal/ 原文链接:[HANA系列]SAP HANA STUDIO客 ...
- 吴恩达机器学习(二) 单变量线性回归(Linear Regression with one variable)
一.模型表示 1.一些术语 如下图,房价预测.训练集给出了房屋面积和价格,下面介绍一些术语: x:输入变量或输入特征(input variable/features). y:输出变量或目标变量(out ...
- CentOS 6.X Python 2.6升级到Python 2.7 【转】
前言:一些第三方框架为了降低复杂性,新的版本已经开始不支持旧版本的python,比如Django这个web框架1.8版本及以上仅仅只支持python2.7及以上版本(记忆中是这个1.8版本),pip安 ...
- GCC 编译参数
-s 这个参数会把符号表从最终的可执行文件中删除.没有符号表,你就不能用gdb调试了,但是程序会更小 -O0 不做任何优化,这是默认的编译选项 -c 只编译不链接,产生.o文件,就是obj文件,不产生 ...
- 【狗屁不通文章生成器】代码分析 (javaScript)
这几天在论坛上看到了一个很有意思的项目,一个生成"狗屁不通"的文章的程序.经过本人确定其的确是"狗屁不通"后,随后又好奇其实现,于是在其[GitHub]项目里( ...