P4424-[HNOI/AHOI2018]寻宝游戏【结论】
正题
题目链接:https://www.luogu.com.cn/problem/P4424
题目大意
\(n\)个\(m\)位二进制数,开始是一个\(0\)。
然后依次对所有二进制数进行\(n\)次\(and\)或者\(or\)操作。
\(q\)次询问给出二进制数\(r_i\),要求有多少种操作序列使得操作完后的数是\(r_i\)。
解题思路
一个暴力的想法,每一位考虑可行的序列,然后取一个交。
考虑如果一个位是\(1\),那么决定它的就是到最后的一个\(or\)上一个\(1\)的一个后缀操作序列。
可以得出一个比较显然的结论就是,把每一位提出来然后翻转得到的一个二进制数\(b\)。如果有\(x<b\)。那么如果\(1\)是\(and\),\(0\)是\(or\),那么操作序列\(x\)一定会使得该位变成\(1\)。
那么我们把所有位算出的\(b\)排个序,然后每次快速统计出一个可行的区间就好了。
时间复杂度\(O(mn\log m+q(n+m))\)
code
#include<cstdio>
#include<cstring>
#include<algorithm>
#define ll long long
using namespace std;
const ll N=1100,M=5100,P=1e9+7;
ll n,m,q,ans;
char c[M],s[M];
struct node{
char a[N];
ll id;
}b[M];
bool operator<(node &x,node &y){
for(ll i=1;i<=n;i++)
if(x.a[i]<y.a[i])return 1;
else if(x.a[i]>y.a[i])return 0;
return 0;
}
signed main()
{
scanf("%lld%lld%lld",&n,&m,&q);
for(ll i=1;i<=m;i++)b[i].id=i;
for(ll i=n;i>=1;i--){
scanf("%s",s+1);
for(ll j=1;j<=m;j++)
b[j].a[i]=s[j];
}
for(ll i=1;i<=m;i++)
b[i].a[0]='0';
for(ll i=0;i<=n;i++)
b[m+1].a[i]=b[0].a[i]='0';
b[m+1].a[0]='1';
sort(b+1,b+1+m);
while(q--){
scanf("%s",c+1);
ll rk0=0,rk1=m+1;
for(ll i=m;i>=1;i--)
if(c[b[i].id]=='0'){rk0=i;break;}
for(ll i=1;i<=m;i++)
if(c[b[i].id]=='1'){rk1=i;break;}
if(rk0>rk1)puts("0");
else{
ll ans=0;
for(ll i=0;i<=n;i++)
ans=(ans*2+b[rk1].a[i]-b[rk0].a[i])%P;
printf("%lld\n",(ans+P)%P);
}
}
return 0;
}
P4424-[HNOI/AHOI2018]寻宝游戏【结论】的更多相关文章
- [Bzoj5285][洛谷P4424][HNOI/AHOI2018]寻宝游戏(bitset)
P4424 [HNOI/AHOI2018]寻宝游戏 某大学每年都会有一次Mystery Hunt的活动,玩家需要根据设置的线索解谜,找到宝藏的位置,前一年获胜的队伍可以获得这一年出题的机会. 作为新生 ...
- 洛谷P4424 [HNOI/AHOI2018]寻宝游戏(思维题)
题意 题目链接 Sol 神仙题Orz Orz zbq爆搜70.. 考虑"与"和"或"的性质 \(0 \& 0 = 0, 1 \& 0 = 0\) ...
- BZOJ5285 & 洛谷4424 & UOJ384:[HNOI/AHOI2018]寻宝游戏——题解
https://www.lydsy.com/JudgeOnline/problem.php?id=5285 https://www.luogu.org/problemnew/show/P4424 ht ...
- 【洛谷4424】[HNOI/AHOI2018] 寻宝游戏(位运算思维题)
点此看题面 大致题意: 给你\(n\)个\(m\)位二进制数.每组询问给你一个\(m\)位二进制数,要求你从\(0\)开始,依次对于这\(n\)个数进行\(and\)或\(or\)操作,问有多少种方案 ...
- [HNOI/AHOI2018]寻宝游戏
题目大意: $n(n\le1000)$个$m(m\le5000)$位的二进制数,第$0$个数为$0$.用$\wedge$和$\vee$将这些数连接起来.$q(q\le1000)$次询问,每次给定一个$ ...
- [HNOI 2018]寻宝游戏
Description 题库链接 给出 \(n\) 个 \(m\) 位的二进制数,在每一个二进制数间插入一个 & 或 | ,第 \(0\) 个数为 \(0\) , \(0,1\) 间也要插入符 ...
- 「HNOI/AHOI2018」游戏
传送门 Luogu 解题思路 这是一道 \(O(n^2)\) 暴力加上 \(\text{random_shuffle}\) 优化 什么鬼 就可以 \(\text{AC}\) 的题. 但还是要讲一下 \ ...
- 【题解】Luogu P4436 [HNOI/AHOI2018]游戏
原题传送门 \(n^2\)过百万在HNOI/AHOI2018中真的成功了qwqwq 先将没门分格的地方连起来,枚举每一个块,看向左向右最多能走多远,最坏复杂度\(O(n^2)\),但出题人竟然没卡(建 ...
- [洛谷P4436] HNOI/AHOI2018 游戏
问题描述 一次小G和小H在玩寻宝游戏,有n个房间排成一列,编号为1,2,...,n,相邻的房间之间都有一道门.其中一部分门上锁(因此需要有对应的钥匙才能开门),其余的门都能直接打开.现在小G告诉了小H ...
随机推荐
- [ES6深度解析]13:let const
当Brendan Eich在1995年设计了JavaScript的第一个版本时,他犯了很多错误,包括从那时起就成为该语言一部分的一些错误,比如Date对象和当你不小心将它们相乘时对象会自动转换为NaN ...
- leaflet 动态线渲染
可以采用leaflet插件 leaflet-ant-path ... <script src="js/leaflet-ant-path.js" type="text ...
- linux下C编程初篇
对于程序设计员来说,makefile是我们绕不过去的一个坎.可能对于习惯Visual C++的用户来说,是否会编写makefile无所谓.毕竟工具本身已经帮我们做好了全部的编译流程.但是在Linux上 ...
- ProjectEuler 006题
题目: The sum of the squares of the first ten natural numbers is, 12 + 22 + ... + 102 = 385 The square ...
- IDEA快捷键命令
Ctrl+Alt+T IDEl 抛异常快捷键ctrl +o 继承类时 继承方法快捷键Ctrl+Alt+左右方向键 回到上次光标停留的地方ALt +left/right 快速切换两个页面ctr ...
- Ajax的GET,POST方法传输数据和接收返回数据
//首先创建一个Ajax对象 function ajaxFunction(){ var xmlHttp; try{ // Firefox, Opera 8.0+, Safari xmlHttp=new ...
- Dapper同时操作任意多张表的实现
1:Dapper的查询帮助类,部分代码,其它新增更新删除可以自行扩展 using Microsoft.Extensions.Configuration; using System; using Sys ...
- MySQL主从不同步、数据不一致解决办法
第一种:通过sql_slave_skip_counter跳过同步错误,适用于一般异常如插入时主键冲突 这种情况一般是在从库进行了写操作,错误提示 Last_SQL_Errno: 1062 Last_S ...
- MySQL 常用的聚合函数
[常用的聚合函数] mysql聚合函数一般用户统计一列值进行计算,然后返回计算结果.一般于分组group by 配合使用. count //统计个数 select count(*) from test ...
- RHCS+Nginx及Fence机制实现高可用集群
RHCS(Red Hat Cluster Suite,红帽集群套件)是Red Hat公司开发整合的一套综合集群软件组件,提供了集群系统中三种集群构架,分别是高可用性集群.负载均衡集群.存储集群,可以通 ...