Luogu P2114[NOI2014]起床困难综合症 【贪心/位运算】By cellur925
所以NOI的题现在简单惹?
30分做法:枚举开始的权值,n²过掉。
100分做法:竟然是贪心qwq。因为我们的计算背景是二进制下,所以我们贪心地想让每一位都是1.我们现在需要解决的问题,就是找到一个开始的攻击值。所以我们可以按位检查一下当前位是否可以为1,能不能更新答案。
Code
#include<cstdio>
#include<algorithm> using namespace std;
typedef long long ll; ll lmax(ll a,ll b)
{
if(b>a) return b;
else return a;
} int n,m;
ll ans;
char opt[];
struct door{
int op;
ll t;
}d[]; ll work(ll x)
{
for(int i=;i<=n;i++)
{
if(d[i].op==)
x=x&d[i].t;
if(d[i].op==)
x=x|d[i].t;
if(d[i].op==)
x=x^d[i].t;
}
return x;
} int main()
{
scanf("%d%d",&n,&m);
for(int i=;i<=n;i++)
{
scanf("%s",opt+);
scanf("%lld",&d[i].t);
if(opt[]=='A') d[i].op=;
else if(opt[]=='O') d[i].op=;
else if(opt[]=='X') d[i].op=;
}
/*for(int i=0;i<=m;i++)
ans=lmax(ans,work(i));*/
for(int i=;i>=;i--)
{
if(ans+(<<i)>m) continue;
if(work(ans)<work(ans+(<<i)))
ans+=(<<i);
}
printf("%lld",work(ans));
return ;
}
Luogu P2114[NOI2014]起床困难综合症 【贪心/位运算】By cellur925的更多相关文章
- luogu P2114 [NOI2014]起床困难综合症 位运算 二进制
		
建议去uoj那里去测,数据比较强 位运算的题目,就得一位一位的分开考虑 然后枚举初始值的最高位是0 是1 的最终攻击 (二进制内)最高位是1肯定比次位是1次次位是1次次次位是1···的大吧,显然 然后 ...
 - 【BZOJ3668】[NOI2014] 起床困难综合症(位运算思想)
		
点此看题面 大致题意: 给定一些位运算操作,让你在\(0\sim m\)范围内选一个初始值,使其在经过这些运算后得到的结果最大. 前置技能:关于位运算 作为一道位运算的题,如果你不知道什么是位运算,那 ...
 - uoj #2  【NOI2014】起床困难综合症  贪心+位运算
		
题目链接 给出n个数, 每个数有特定的一种操作, &|^三种, 给出一个m, 初始值属于[0,m],选定一个初始值, 使所有操作做完之后的值最大, 输出这个最大值. 1, 从最高位贪心, 如果 ...
 - Luogu P2114_[NOI2014]起床困难综合症 贪心
		
思路:按位贪心. 提交:1次 题解: 可以先处理出对于全$0$串和全$1$串最后每一位的结果.(每一位 从 $0$ $or$ $1$ 变成 $0$ $or$ $1$) 对于每一位,若不能变成$1$,则 ...
 - Luogu2114 [NOI2014]起床困难综合症 【位运算】
		
题目分析: 按位处理即可 代码: #include<bits/stdc++.h> using namespace std; ; int n,m; int a[maxn],b[maxn]; ...
 - [P2114] [NOI2014]起床困难综合症 (位运算)
		
题面 传送门:https://www.luogu.org/problemnew/show/P2114 Solution 一道很有意思的位运算题. 要做这一题,我们首先得了解一个很重要的特点 位运算过程 ...
 - 洛谷P2114 [NOI2014]起床困难综合症
		
P2114 [NOI2014]起床困难综合症 题目描述 21世纪,许多人得了一种奇怪的病:起床困难综合症,其临床表现为:起床难,起床后精神不佳.作为一名青春阳光好少年,atm一直坚持与起床困难综合症作 ...
 - 洛谷 P2114 [NOI2014]起床困难综合症 解题报告
		
P2114 [NOI2014]起床困难综合症 题目描述 21世纪,许多人得了一种奇怪的病:起床困难综合症,其临床表现为:起床难,起床后精神不佳.作为一名青春阳光好少年,atm一直坚持与起床困难综合症作 ...
 - P2114 [NOI2014]起床困难综合症(二进制)
		
P2114 [NOI2014]起床困难综合症 我们开始设俩数,一个二进制表示全是1,另一个全是0(就是2147483647 和 0 辣) 蓝后跑一遍门 于是最后有4种情况 1->0,1-> ...
 
随机推荐
- 关于 underscore 中模板引擎的应用演示样例
			
//关于 underscore 中模板引擎的应用演示样例 <!doctype html> <html> <head> <meta charset=" ...
 - Spark 学习笔记:(三)Spark SQL
			
参考:https://spark.apache.org/docs/latest/sql-programming-guide.html#overview http://www.csdn.net/arti ...
 - 在VC中动态加载ODBC的方法
			
在使用VC.VB.Delphi等高级语言编写数据库应用程序时,往往需要用户自己在控制面板中配置ODBC数据源.对于一般用户而言,配置ODBC数据源可能是一件比较困难的工作.而且,在实际应用中,用户往往 ...
 - object-c iOS 教程 git for mac
			
本文转载至 http://blog.csdn.net/u011728347/article/details/10035191 http://rypress.com/tutorials/object ...
 - POJ 1182 食物链(并查集)
			
题目链接 经过宝哥的讲解,终于对这种问题有了进一步的理解.根据flag[x]和flag[y]求flag[tx]是最关键的了. 0吃1,1吃2,2吃0. 假设flag[tx] = X; 那么X + fl ...
 - redis中的五种基本的数据结构
			
1 String 基本的数据类型. 2 list 2.1 将元素放入一个list中 rpush mylist A rpush mylist B rpush mylist A 如果mylist本来是不存 ...
 - Python 中的字节与字节数组
			
Python 中的字节与字节数组 - Python - 伯乐在线 http://python.jobbole.com/84839/
 - hdu 1757 A Simple Math Problem (矩阵高速幂)
			
和这一题构造的矩阵的方法同样. 须要注意的是.题目中a0~a9 与矩阵相乘的顺序. #include <iostream> #include <cstdio> #include ...
 - C# 事件处理与自定义事件
			
http://blog.csdn.net/cyp403/article/details/1514023 图一 ...
 - 根据用户时区显示当地时间 javascript+php
			
在跨时区应用中会用到下面代码,这是以前写的一段代码. 服务器保存相关时间配置,保存形式为GMT时间,客户端需要根据客户所在时区做相应显示,以符合客户习惯. 1. [代码][JavaScript]代码 ...