【题解】HNOI2018寻宝游戏
太厉害啦……感觉看到了正解之后整个人都惊呆了一样。真的很强%%%
首先要注意到一个性质。位运算列与列之间是不会相互影响的,那么我们先观察使一列满足条件的操作序列需要满足什么条件。&0时,不论之前是什么数字,结果都是0,而|1时,结果都是1。我们现在将&用1表示,而|用0表示。这样我们将我们&|的操作序列转化为了一个01串。假设这一列数字操作出来做后的结果应当是1,显然有最后的一个|1在&0之后。我们比较一下两个串,同为1或者同为0则跳过(&1 和 |0 不影响数字的大小),然后当出现操作序列是1而数字序列是0时,就一定不合法;反之则一定合法(|1 和 &0 谁先出现)。
写到这里不知道有没有感觉出一点什么?其实就是在比较两个串的字典序啊。结果为1:操作串字典序 < 数字序列字典序;结果为0 :操作串字典序 >= 数字序列字典序。到这里正解就呼之欲出了:将所有的数字串(一列上的)按反序(自底向上)字典序排列,此后只要求出临界的两个字符串,答案就是这两个字符串的数字差啦。
#include <bits/stdc++.h>
using namespace std;
#define maxn 1105
#define maxm 5105
#define mod 1000000007
#define ll long long
#define int long long
ll n, m, q, sum[maxm], MAXX;
char Q[maxm], S[maxm]; struct node
{
int id;
char a[maxn];
}ch[maxm]; int read()
{
int x = , k = ;
char c;
c = getchar();
while(c < '' || c > '') { if(c == '-') k = -; c = getchar(); }
while(c >= '' && c <= '') x = x * + c - '', c = getchar();
return x * k;
} bool cmp(node a, node b)
{
for(int i = ; i <= n; i ++)
{
int k1 = a.a[i] - '', k2 = b.a[i] - '';
if(k1 == k2) continue;
else if(k1 > k2) return ;
else return ;
}
} ll Get_num(int x) //y - x
{
int ret1 = ;
for(int i = ; i <= n; i ++)
{
ret1 = ret1 * % mod;
if(ch[x].a[i] - '') ret1 += ;
}
return ret1;
} ll Qpow(int x, int t)
{
ll base = ;
for(; t; t >>= , x = (x * x) % mod)
if(t & ) base = (base * x) % mod;
return base;
} signed main()
{
n = read(), m = read(), q = read();
MAXX = Qpow(, n);
for(int i = ; i <= n; i ++)
{
scanf("%s", S + );
for(int j = ; j <= m; j ++)
ch[j].a[n - i + ] = S[j];
}
for(int i = ; i <= m; i ++) ch[i].id = i;
sort(ch + , ch + + m, cmp);
for(int i = ; i <= m; i ++)
sum[i] = Get_num(i);
for(int i = ; i <= q; i ++)
{
scanf("%s", Q + );
int mark1 = , mark2 = ;
for(int j = ; j <= m; j ++)
if(Q[ch[j].id] - '')
{
mark1 = j;
break;
}
for(int j = m; j >= ; j --)
{
if(!(Q[ch[j].id] - ''))
{
mark2 = j;
break;
}
}
if(mark1 && mark2 && mark2 >= mark1) printf("0\n");
else
{
if(mark1) printf("%lld\n", (sum[mark1] - sum[mark2] + mod) % mod);
else if(!mark1 && mark2) printf("%lld\n", (MAXX - sum[mark2] + mod) % mod);
else printf("%lld\n", MAXX);
}
}
return ;
}
【题解】HNOI2018寻宝游戏的更多相关文章
- 【BZOJ5285】[HNOI2018]寻宝游戏(神仙题)
[BZOJ5285][HNOI2018]寻宝游戏(神仙题) 题面 BZOJ 洛谷 题解 既然是二进制按位的运算,显然按位考虑. 发现这样一个关系,如果是\(or\)的话,只要\(or\ 1\),那么无 ...
- 5285: [Hnoi2018]寻宝游戏
5285: [Hnoi2018]寻宝游戏 链接 分析: 从下面依次确定运算符号,然后在确定的过程中,需要确定的位数会逐渐减少.比如最后有一个1,如果在从下往上确定了一个or 1,那么再往前可以随便选了 ...
- BZOJ.5285.[AHOI/HNOI2018]寻宝游戏(思路 按位计算 基数排序..)
BZOJ LOJ 洛谷 话说vae去年的专辑就叫寻宝游戏诶 只有我去搜Mystery Hunt和infinite corridor了吗... 同样按位考虑,假设\(m=1\). 我们要在一堆\(01\ ...
- [HNOI2018]寻宝游戏(题解转载自别处)
题解(自别处转载): Luogu CSDN 这题关键是将运算符也替换成0,1 然后在运算符与原串混杂里找规律. 而且替换的方式也有所要求,考场上两种替换方式都要尝试. #include <bit ...
- HNOI2018寻宝游戏
https://www.luogu.org/problemnew/show/P4424 题解 我们首先按位考虑. 如果有一位最终的结果为1,那么我们可以把树的序列看成一个二进制数,先出现的在底位,后出 ...
- 【比赛】HNOI2018 寻宝游戏
考试的时候就拿了30points滚粗了 听说myy对这题的倒推做法很无奈,官方题解在此 正解思路真的很巧妙,也说的很清楚了 就是分别考虑每一位,会发现题解中的那个性质,然后把询问的二进制数按照排序后的 ...
- loj2494 [hnoi2018]寻宝游戏
题意:给你n个元素的数组a.你可以在每个元素之前添加and和or的符号.每次询问最后变成r有多少种添号情况. n<=1000,m<=5000,q<=1000. 标程: #includ ...
- bzoj 5285: [Hnoi2018]寻宝游戏
Description Solution 把输入的 \(n\) 个二进制数看作一个大小为 \(n*m\) 的矩阵 把每一列压成一个二进制数,其中最高位是最下面的元素 然后就有了 \(m\) 个二进制数 ...
- bzoj千题计划310:bzoj5285: [Hnoi2018]寻宝游戏(思维题+哈希)
https://www.lydsy.com/JudgeOnline/problem.php?id=5285 |0 和 &1 没有影响 若填‘|’,记为0,若填‘&’,记为1 先只考虑最 ...
随机推荐
- tp3.2报错;syntax error, unexpected 'function' (T_FUNCTION), expecting identifier (T_STRING) or \\ (T_NS_SEPARATOR)
出错原因:这个是php版本问题,laravel5.1的php版本要求是PHP >= 5.5.9,切换一下PHP版本就行.
- 【Js】JSON对象、JSON字符的使用总结
JSON对象 / JSON字符串区别 抛出一个最常见的疑问:什么是“JSON对象”,什么是“JSON字符串”,它俩的区别是什么? 废话不多说,直接上代码. 1.JSON对象: // javascrip ...
- java基础day05---界面
java基础day05---界面 1.GUI:图形用户界面(Graphics User Interface) 开发工具包AWT抽象窗口把工具箱===>swing 解决了awt存在的lcd问题== ...
- 001---Linux系统的启动过程
Linux系统的启动过程 按下电源 开机自检(BIOS):检查cpu.内存.硬盘是否有问题,找到启动盘. MBR引导(master boot record):主引导记录,读取存储设备的512bytes ...
- 在WPF中自定义控件(1)
原文:在WPF中自定义控件(1) 在WPF中自定义控件(1):概述 周银辉一, 不一定需要自定 ...
- P1078 文化之旅
P1078 文化之旅 题目描述 有一位使者要游历各国,他每到一个国家,都能学到一种文化,但他不愿意学习任何一 种文化超过一次(即如果他学习了某种文化,则他就不能到达其他有这种文化的国家).不 同的国家 ...
- 关于 spring-aop理解
对于Aop 一直理解很是不到位 谈谈自己理解! Aop : Aspect: 切面 joinpoint 连接点 pointCut 切点 Advice 增强 targert 目标对象 w ...
- Wordpress 设置后台自定义post 排序
创建新的 Post type时,文章在后台默认使用 Titile 列进行升序排序,但是通常情况下我们需要按日期 Date 进行降序排序, function wpse_81939_post_types_ ...
- 启动 SQL Server 管理 Studio 在 SQL Server 2008R2 中的错误消息:"无法读取此系统上以前注册的服务器的列表" 解决方法
问题: 服务器被人直接停掉,重启后,发现sqlserver2008r2 启动管理器报错: "无法读取此系统上以前注册的服务器的列表" 如图: 点击继续,进入后: 解决方法: 点击上 ...
- shell语句for循环
一:常用格式 格式一 for 变量 do 语句 done 格式二 for 变量 in 列表 do 语句 done 格式三 for ((变量=初始值; 条件判断; 变量变化)) do 语句 done 二 ...