[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 一直坚持与起床困难综合症作斗争.通过研究相关文献,他找 ...
随机推荐
- laravel框架学习-缓存,事件
缓存配置:app/config/cache.php 缓存: 增加缓存项: Cache::put( 'key', 'value', $Cachetime ); 在缓存中增加一个不存在 ...
- java中的Collection集合类
随着1998年JDK 1.2的发布,同时新增了常用的Collections集合类,包含了Collection和Map接口.而Dictionary类是在1996年JDK 1.0发布时就已经有了.它们都可 ...
- 用Composer获取第三方资源总是失败咋办?
凉拌!!! 不不不,哥可是一个有追求的人,没那么容易放弃的! 所以我选择用中国全量镜像,https://pkg.phpcomposer.com/ 使用方法: 对,就是命令行方法,我最喜欢的方法!!! ...
- 基于epoll实现简单的web服务器
1. 简介 epoll 是 Linux 平台下特有的一种 I/O 复用模型实现,于 2002 年在 Linux kernel 2.5.44 中被引入.在 epoll 之前,Unix/Linux 平台下 ...
- day2(字符串、格式化输出、运算符、流程控制)
一.字符串 在Python中,加了引号的字符都被认为是字符串! 单引号.双引号.多引号的区别? 单引号和 双引号没有任何区别,但是某种情况下需要单双配合 如 msg = " My name ...
- Python使用Mysql官方驱动(取出dict类型的数据)
简介 虽然Python有很多连接mysql的库,比如mysqldb, pymysql~这些都很方便,现在就教大家使用mysql的官方库来操作mysql. 安装 windows: 下载链接 选择自己的w ...
- mysql 集群 监控
部署mysql高可用集群(mysql-mmm+主从同步)4台数据库服务器:四个数据库之保留初始的四个库,其他库全部删除 主机158 主机137 主机99 主机67 主机102(可与其他四台ping通即 ...
- 沉淀,再出发——手把手教你使用VirtualBox搭建含有三个虚拟节点的Hadoop集群
手把手教你使用VirtualBox搭建含有三个虚拟节点的Hadoop集群 一.准备,再出发 在项目启动之前,让我们看一下前面所做的工作.首先我们掌握了一些Linux的基本命令和重要的文件,其次我们学会 ...
- MS SQL 事务日志管理小结
本文是对SQL Server事务日志的总结,文章有一些内容和知识来源于官方文档或一些技术博客,本文对引用部分的出处都有标注. 事务日志介绍 在SQL Server中,事务日志是数据库的重要组件,如 ...
- 视频显示格式720p
720p是一种视频显示格式.字母p意为逐行扫描(progressive scan),数字720则表示水平方向有720条扫描线. 通常720p的画面分辨率为1280×720,一般亦可称为高画质(HD). ...