[BZOJ3668] [Noi2014] 起床困难综合症 (贪心)
Description
Input
第1行包含2个整数,依次为n,m,表示drd有n扇防御门,atm的初始攻击力为0到m之间的整数。接下来n行,依次表示每一扇防御门。每行包括一个字符串op和一个非负整数t,两者由一个空格隔开,且op在前,t在后,op表示该防御门所对应的操作, t表示对应的参数。
Output
一行一个整数,表示atm的一次攻击最多使 drd 受到多少伤害。
Sample Input
AND 5
OR 6
XOR 7
Sample Output
HINT
【样例说明】
atm可以选择的初始攻击力为0,1,...,10。
假设初始攻击力为4,最终攻击力经过了如下计算
4 AND 5 = 4
4 OR 6 = 6
6 XOR 7 = 1
类似的,我们可以计算出初始攻击力为1,3,5,7,9时最终攻击力为0,初始攻击力为0,2,4,6,8,10时最终攻击力为1,因此atm的一次攻击最多使 drd 受到的伤害值为1。
0<=m<=10^9
0<=t<=10^9
一定为OR,XOR,AND 中的一种
【运算解释】
例如,我们将十进制数5与十进制数3分别进行OR,XOR 与 AND 运算,可以得到如下结果:
0101 (十进制 5) 0101 (十进制 5) 0101 (十进制 5)
OR 0011 (十进制 3) XOR 0011 (十进制 3) AND 0011 (十进制 3)
= 0111 (十进制 7) = 0110 (十进制 6) = 0001 (十进制 1)
Source
Solution
依然缺一个条件:$n\leq 10^5$
从高位往低位,算一下攻击力的当前位取$0$得到的结果$r_0$和取$1$得到的结果$r_1$
有这么几种可能
- $r_0=1,r_1=0$,不用多想,这一位肯定选$0$
- $r_0=1,r_1=1$,因为如果这一位选$0$,后面几位就可以有更多的选择所以还选$0$
- $r_0=0,r_1=0$,同第$2$条,仍然选$0$
- $r_0=0,r_1=1$,第$2$第$3$条所谓的选择是在这一条体现的,如果这一位选了$1$不会超过$m$就选$1$,否则选$0$,因为高位的$1$显然比低位的$1$划算
#include <bits/stdc++.h>
using namespace std;
int n, def[][]; bool check(int bit, int x)
{
for(int i = ; i <= n; ++i)
if(def[i][] == )
x &= def[i][] & << bit;
else if(def[i][] == )
x |= def[i][] & << bit;
else x ^= def[i][] & << bit;
return x;
} int main()
{
int m, x, ans = ;
bool r0, r1;
char op[];
scanf("%d%d", &n, &m);
for(int i = ; i <= n; ++i)
{
scanf("%s%d", op, &def[i][]);
if(op[] == 'A') def[i][] = ;
else if(op[] == 'O') def[i][] = ;
else def[i][] = ;
}
for(int i = ; ~i; --i)
{
r0 = check(i, ), r1 = check(i, << i);
if(r0 || !r1) continue;
if((ans | << i) <= m) ans |= << i;
}
for(int i = ; i <= n; ++i)
if(def[i][] == ) ans &= def[i][];
else if(def[i][] == ) ans |= def[i][];
else ans ^= def[i][];
printf("%d\n", ans);
return ;
}
当然可以把每一位放到一起算,速度会快很多
#include <bits/stdc++.h>
using namespace std;
int def[][];
int main()
{
int n, m, r0 = , r1 = ( << ) - , ans = ;
char op[];
scanf("%d%d", &n, &m);
for(int i = ; i <= n; ++i)
{
scanf("%s%d", op, &def[i][]);
if(op[] == 'A') def[i][] = ;
else if(op[] == 'O') def[i][] = ;
else def[i][] = ;
}
for(int i = ; i <= n; ++i)
if(def[i][] == ) r0 &= def[i][], r1 &= def[i][];
else if(def[i][] == ) r0 |= def[i][], r1 |= def[i][];
else r0 ^= def[i][], r1 ^= def[i][];
for(int i = ; ~i; --i)
{
if(r0 & << i || !(r1 & << i)) continue;
if((ans | << i) <= m) ans |= << i;
}
for(int i = ; i <= n; ++i)
if(def[i][] == ) ans &= def[i][];
else if(def[i][] == ) ans |= def[i][];
else ans ^= def[i][];
printf("%d\n", ans);
return ;
}
[BZOJ3668] [Noi2014] 起床困难综合症 (贪心)的更多相关文章
- BZOJ3668: [Noi2014]起床困难综合症(贪心 二进制)
Time Limit: 10 Sec Memory Limit: 512 MBSubmit: 2708 Solved: 1576[Submit][Status][Discuss] Descript ...
- bzoj3668 [Noi2014]起床困难综合症——贪心
题目:https://www.lydsy.com/JudgeOnline/problem.php?id=3668 一开始想着倒序推回去看看这一位能不能达到来着,因为这样好中途退出(以为不这样会T): ...
- BZOJ 3668: [Noi2014]起床困难综合症( 贪心 )
之前以为xor,or,and满足结合律...然后连样例都过不了 早上上体育课的时候突然想出来了...直接处理每一位是1,0的最后结果, 然后从高位到低位贪心就可以了... 滚去吃饭了.. ------ ...
- [Bzoj3668][Noi2014]起床困难综合症(位运算)
3668: [Noi2014]起床困难综合症 Time Limit: 10 Sec Memory Limit: 512 MBSubmit: 2612 Solved: 1500[Submit][St ...
- bzoj3668: [Noi2014]起床困难综合症
从高位到低位枚举期望的应该是ans最高位尽量取一.如果该数最高位为o的话能够取得1直接更新ans否则判断该位取1是否会爆m不会的话就加上. #include<cstdio> #includ ...
- bzoj千题计划238:bzoj3668: [Noi2014]起床困难综合症
http://www.lydsy.com/JudgeOnline/problem.php?id=3668 这..一位一位的来就好了呀 #include<cstdio> #include&l ...
- 【bzoj3668】[Noi2014]起床困难综合症 贪心
原文地址:http://www.cnblogs.com/GXZlegend/p/6797090.html 题目描述 21 世纪,许多人得了一种奇怪的病:起床困难综合症,其临床表现为:起床难,起床后精神 ...
- BZOJ3668 [Noi2014]起床困难综合症 【贪心】
题目 21 世纪,许多人得了一种奇怪的病:起床困难综合症,其临床表现为:起床难,起床后精神不佳.作为一名青春阳光好少年,atm 一直坚持与起床困难综合症作斗争.通过研究相关文献,他找到了该病的发病原因 ...
- [bzoj3668][Noi2014][起床困难综合症] (按位贪心)
Description 21 世纪,许多人得了一种奇怪的病:起床困难综合症,其临床表现为:起床难,起床后精神不佳.作为一名青春阳光好少年,atm 一直坚持与起床困难综合症作斗争.通过研究相关文献,他找 ...
随机推荐
- Node.js爬取豆瓣数据
一直自以为自己vue还可以,一直自以为webpack还可以,今天在慕课逛node的时候,才发现,自己还差的很远.众所周知,vue-cli基于webpack,而webpack基于node,对node不了 ...
- 阿里云 virtual memory exhausted: 无法分配内存
在阿里云买了个云服务器,内存1G.编译php时出现下面的错误: virtual memory exhausted: Cannot allocate memory 问题原因:由于物理内存本身很小,且阿里 ...
- LINUX下的U盘挂载
linux下如果没有图形界面的情况下就要我们自己熟悉命令来挂载U盘,下面给大家详细描述下U盘的挂载过程. 1. 插入U盘 2. #sudo fdisk –l 查看所挂载盘符名称如下图,假设盘符名称为s ...
- 在Windows下为PHP5.5安装redis扩展
使用phpinfo()函数查看PHP的版本信息,这会决定扩展文件版本 根据PHP版本号,编译器版本号和CPU架构, 选择php_redis-2.2.5-5.5-ts-vc11-x86.zip和ph ...
- Linux 安装配置 FTP 服务 (vsftpd)
1. 安装 vsftpd yum install vsftpd -y 2. 创建用户 record adduser -s /bin/nologin -d /var/RecordFile/ record ...
- eslint 入门项目搭建过程
github 地址 : https://github.com/gebin/eslint-demo 运行该项目 npm install npm start 访问 http://localhost:900 ...
- Python基础总结
刚学习Python时,边学边总结的,采用思维导图的形式, 适合回顾使用.内容参考<Python:从入门到实践>一书. 再给出一张Datacamp网站上的一张关于Python基础的总 ...
- pinvoke 数据交互笔记
intptr to array string string[] _outputStrArray=null; int channelCount = 0;///返回数组大小 In ...
- 终极解决方案:java.security.cert.CertificateException: Certificates does not conform to algorithm constraints
报错信息 javax.net.ssl.SSLHandshakeException: java.security.cert.CertificateException: Certificates does ...
- Create小程序
我有时候喜欢直接用命令行创建.编译.执行java文件, 每次创建一个文件都要新建一个.java文件,然后再编辑.java文件加入类名,主函数…… 这些流程我有点厌倦,于是就编写了一个超级简单的自动创建 ...