正题

题目链接: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]寻宝游戏【结论】的更多相关文章

  1. [Bzoj5285][洛谷P4424][HNOI/AHOI2018]寻宝游戏(bitset)

    P4424 [HNOI/AHOI2018]寻宝游戏 某大学每年都会有一次Mystery Hunt的活动,玩家需要根据设置的线索解谜,找到宝藏的位置,前一年获胜的队伍可以获得这一年出题的机会. 作为新生 ...

  2. 洛谷P4424 [HNOI/AHOI2018]寻宝游戏(思维题)

    题意 题目链接 Sol 神仙题Orz Orz zbq爆搜70.. 考虑"与"和"或"的性质 \(0 \& 0 = 0, 1 \& 0 = 0\) ...

  3. BZOJ5285 & 洛谷4424 & UOJ384:[HNOI/AHOI2018]寻宝游戏——题解

    https://www.lydsy.com/JudgeOnline/problem.php?id=5285 https://www.luogu.org/problemnew/show/P4424 ht ...

  4. 【洛谷4424】[HNOI/AHOI2018] 寻宝游戏(位运算思维题)

    点此看题面 大致题意: 给你\(n\)个\(m\)位二进制数.每组询问给你一个\(m\)位二进制数,要求你从\(0\)开始,依次对于这\(n\)个数进行\(and\)或\(or\)操作,问有多少种方案 ...

  5. [HNOI/AHOI2018]寻宝游戏

    题目大意: $n(n\le1000)$个$m(m\le5000)$位的二进制数,第$0$个数为$0$.用$\wedge$和$\vee$将这些数连接起来.$q(q\le1000)$次询问,每次给定一个$ ...

  6. [HNOI 2018]寻宝游戏

    Description 题库链接 给出 \(n\) 个 \(m\) 位的二进制数,在每一个二进制数间插入一个 & 或 | ,第 \(0\) 个数为 \(0\) , \(0,1\) 间也要插入符 ...

  7. 「HNOI/AHOI2018」游戏

    传送门 Luogu 解题思路 这是一道 \(O(n^2)\) 暴力加上 \(\text{random_shuffle}\) 优化 什么鬼 就可以 \(\text{AC}\) 的题. 但还是要讲一下 \ ...

  8. 【题解】Luogu P4436 [HNOI/AHOI2018]游戏

    原题传送门 \(n^2\)过百万在HNOI/AHOI2018中真的成功了qwqwq 先将没门分格的地方连起来,枚举每一个块,看向左向右最多能走多远,最坏复杂度\(O(n^2)\),但出题人竟然没卡(建 ...

  9. [洛谷P4436] HNOI/AHOI2018 游戏

    问题描述 一次小G和小H在玩寻宝游戏,有n个房间排成一列,编号为1,2,...,n,相邻的房间之间都有一道门.其中一部分门上锁(因此需要有对应的钥匙才能开门),其余的门都能直接打开.现在小G告诉了小H ...

随机推荐

  1. jvm系列(五):jvm调优-从eclipse开始

    概述 什么是jvm调优呢?jvm调优就是根据gc日志分析jvm内存分配.回收的情况来调整各区域内存比例或者gc回收的策略:更深一层就是根据dump出来的内存结构和线程栈来分析代码中不合理的地方给予改进 ...

  2. Mysql---C#在cmd中使用mysqldump导出sql文件

    一.概述 本文描述了在C#中利用mysqldump工具导出sql文件. 二.代码片段 CmdHelper类代码如下: public class CmdHelper { public static st ...

  3. C++ 子类调用父类的方法,静态方法的调用

    #include <iostream> class  A { public: A(); ~ A(); virtualvoid say() { std::cout << &quo ...

  4. Bing每日壁纸的RESTful接口实现

    0x00 存在意义 权且当作Docker打包的练习. 显然可以通过构造请求获得每天的壁纸,但是如果想要优雅地在其它地方使用这一网络资源,封装一个RESTful API将会保证整洁美观,在编写CSS等场 ...

  5. 学习小记: Kaggle Learn - Machine Learning Explainability

    Method Feature(s) Sample(s) Result Value/Feature Permutation Importance 1 all validation samples Sin ...

  6. AI 常见术语总结

      BN(Batch-normalization)在一层的输出上计算所有特征映射的均值和标准差,并且使用这些值规范化它们的响应.因此使得所有神经图(neural maps)在同样范围有响应,而且是零均 ...

  7. vue 接入 vod-js-sdk-v6.js 完成视频上传

    东西有点多,耐心看完.按照操作一步一步来,绝对能成功 首先:npm 引入 npm install vod-js-sdk-v6 mian.js  全局引入  //腾讯云点播 import TcVod f ...

  8. 云原生 AI 前沿:Kubeflow Training Operator 统一云上 AI 训练

    分布式训练与 Kubeflow 当开发者想要讲深度学习的分布式训练搬上 Kubernetes 集群时,首先想到的往往就是 Kubeflow 社区中形形色色的 operators,如 tf-operat ...

  9. windows/linux 页面编码区别导致 python 乱码

    http://blog.csdn.net/haiross/article/details/36189103 可以先看下这篇文章..写的比较用心和详细并且高深..我只是记流水账的. 直到今天我才注意到 ...

  10. VS dll 引用依赖

    在公司实习过程中,经常遇到三个问题: 开发环境 dll引用依赖 dll版本控制 一般公司都会配置开发/测试/Lab/线上四个环境,之后不管时开发什么项目,都与环境分不开边.这个和dll版本控制暂且记下 ...