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 ...
随机推荐
- jvm系列(五):jvm调优-从eclipse开始
概述 什么是jvm调优呢?jvm调优就是根据gc日志分析jvm内存分配.回收的情况来调整各区域内存比例或者gc回收的策略:更深一层就是根据dump出来的内存结构和线程栈来分析代码中不合理的地方给予改进 ...
- Mysql---C#在cmd中使用mysqldump导出sql文件
一.概述 本文描述了在C#中利用mysqldump工具导出sql文件. 二.代码片段 CmdHelper类代码如下: public class CmdHelper { public static st ...
- C++ 子类调用父类的方法,静态方法的调用
#include <iostream> class A { public: A(); ~ A(); virtualvoid say() { std::cout << &quo ...
- Bing每日壁纸的RESTful接口实现
0x00 存在意义 权且当作Docker打包的练习. 显然可以通过构造请求获得每天的壁纸,但是如果想要优雅地在其它地方使用这一网络资源,封装一个RESTful API将会保证整洁美观,在编写CSS等场 ...
- 学习小记: Kaggle Learn - Machine Learning Explainability
Method Feature(s) Sample(s) Result Value/Feature Permutation Importance 1 all validation samples Sin ...
- AI 常见术语总结
BN(Batch-normalization)在一层的输出上计算所有特征映射的均值和标准差,并且使用这些值规范化它们的响应.因此使得所有神经图(neural maps)在同样范围有响应,而且是零均 ...
- vue 接入 vod-js-sdk-v6.js 完成视频上传
东西有点多,耐心看完.按照操作一步一步来,绝对能成功 首先:npm 引入 npm install vod-js-sdk-v6 mian.js 全局引入 //腾讯云点播 import TcVod f ...
- 云原生 AI 前沿:Kubeflow Training Operator 统一云上 AI 训练
分布式训练与 Kubeflow 当开发者想要讲深度学习的分布式训练搬上 Kubernetes 集群时,首先想到的往往就是 Kubeflow 社区中形形色色的 operators,如 tf-operat ...
- windows/linux 页面编码区别导致 python 乱码
http://blog.csdn.net/haiross/article/details/36189103 可以先看下这篇文章..写的比较用心和详细并且高深..我只是记流水账的. 直到今天我才注意到 ...
- VS dll 引用依赖
在公司实习过程中,经常遇到三个问题: 开发环境 dll引用依赖 dll版本控制 一般公司都会配置开发/测试/Lab/线上四个环境,之后不管时开发什么项目,都与环境分不开边.这个和dll版本控制暂且记下 ...