Codeforces Round #456 B题

一、题意
给你一个n和一个k,让你从[1, n]区间内选k个数,这k个数异或和最大。
二、思路
我一开始看到这种题,不自觉地就想到,莫非又要搞很复杂的线段树、主席树?貌似还有些难搞啊。然而事实是:Codeforces最不喜欢出的题目就模板题,相反,他的题更倾向于想法,看看你能不能想到,能不能考虑全。我个人觉得,这样的题做起来还更有意思。
事实是,这题的思路:选k个数,使异或和最大,那么,两种情况:
(1)k = 1,那毫无疑问选最大的数,输出n;
(2)k > 1,那就输出2i - 1。其中,i是n的二进制表示的长度。PS:前导0肯定不算的啦,从最高位1开始算起。
PS:异或很重要的性质,这个是必须掌握的哦。二进制中,任何数(0或1),和0异或,都是它本身。
三、吐槽&总结时间
我想到差不多上面的思路后,一开始想的是,考虑最大的那个数的二进制表示s,如果s中0的个数 <= k,那么,肯定能找到k个比n小的数,他们就是2i。这样,把他们全部和s逻辑或,最后输出s的十进制就OK了。然后,被hack了T_T
想了好长一会儿,终于发现,上面的方法有问题,如果s中0的个数 > k,也可以把s中的0变成1啊,可以选2i+2j 这种的啊。既然这样,那么,我就产生了一个很想想就觉得很傻逼的想法:既然输入数据k >= 1,那么,答案永远都是2i - 1(其中,i是n的二进制表示的长度)。我当时脑中的想法是:去[1, n]里面选k个数,和n异或的最大值。尽管我看了很多遍题目。也看了很多遍a1⊕a2⊕……⊕ak,都没发现自己的想法有错,所以,第二次提交又hacked,而且,我提交后,很肯定地认为自己没错了,把题目锁了,想去hack别人一发,消消气,结果,我那题就这样错了。直到写这篇题解前,我去补题,把昨晚的代码交上去被样例20卡掉了,我才顿悟:真的太糊涂了。
很多次比赛都是这样,并不是自己想不到那个点子,而是总是被某个“非常不起眼”卡到绝望、卡到失败。
这个我觉得这毛病和心态有关,要好好调整。一定要,必须要。
四、源代码
#include<bits/stdc++.h>
using namespace std;
typedef long long LL;
int main() {
LL a, b;
while(~scanf("%lld%lld", &a, &b)) {
){
printf("%lld\n", a);
continue;
}
;
; a > ; ++i) {
a >>= ;
}
printf();
}
;
}
Codeforces Round #456 B题的更多相关文章
- Codeforces Round #456 (Div. 2)
Codeforces Round #456 (Div. 2) A. Tricky Alchemy 题目描述:要制作三种球:黄.绿.蓝,一个黄球需要两个黄色水晶,一个绿球需要一个黄色水晶和一个蓝色水晶, ...
- Codeforces Round #456 (Div. 2) B题
B. New Year's Evetime limit per test1 secondmemory limit per test256 megabytesinputstandard inputout ...
- Educational Codeforces Round 27 补题
题目链接:http://codeforces.com/contest/845 A. Chess Tourney 水题,排序之后判断第n个元素和n+1个元素是不是想等就可以了. #include < ...
- cordforce Educational Codeforces Round 47 补题笔记 <未完>
题目链接 http://codeforces.com/contest/1009 A. Game Shopping 直接模拟即可,用了一个队列来存储账单 #include <iostream> ...
- Codeforces Round #456 (Div. 2) B. New Year's Eve
传送门:http://codeforces.com/contest/912/problem/B B. New Year's Eve time limit per test1 second memory ...
- Codeforces Round #456 (Div. 2) A. Tricky Alchemy
传送门:http://codeforces.com/contest/912/problem/A A. Tricky Alchemy time limit per test1 second memory ...
- Codeforces Round #456 (Div. 2) 912E E. Prime Gift
题 OvO http://codeforces.com/contest/912/problem/E 解 首先把这个数字拆成个子集,各自生成所有大小1e18及以下的积 对于最坏情况,即如下数据 16 2 ...
- Codeforces Round #456 (Div. 2) 912D D. Fishes
题: OvO http://codeforces.com/contest/912/problem/D 解: 枚举每一条鱼,每放一条鱼,必然放到最优的位置,而最优位置即使钓上的概率最大的位置,即最多的r ...
- Educational Codeforces Round 15 套题
这套题最后一题不会,然后先放一下,最后一题应该是大数据结构题 A:求连续最长严格递增的的串,O(n)简单dp #include <cstdio> #include <cstdlib& ...
随机推荐
- Java线程池Executor使用
合理利用线程池能够带来三个好处.第一:降低资源消耗.通过重复利用已创建的线程降低线程创建和销毁造成的消耗.第二:减少系统对于,外部 服务的响应时间的等待.第三:提高线程的可管理性.线程是稀缺资源,如果 ...
- Java Spring-注解进行属性注入
2017-11-06 21:19:43 一.Spring的注解装配BeanSpring2.5 引入使用注解去定义Bean @Component 描述Spring框架中Bean Spring的框架中提供 ...
- 雷林鹏分享:JSP 简介
JSP 简介 什么是Java Server Pages? JSP全称Java Server Pages,是一种动态网页开发技术.它使用JSP标签在HTML网页中插入Java代码.标签通常以<%开 ...
- hdu 6386 Age of Moyu (重边判断)
本来用一个map判重边结果T了, 实际上可以直接给边上打标记即可 int n, m; struct _ {int to,w,vis;}; vector<_> g[N]; int dis[N ...
- UVA-10779 Collectors Problem (网络流建模)
题目大意:有n个人,已知每人有ki个糖纸,并且知道每张糖纸的颜色.其中,Bob希望能和同伴交换使得手上的糖纸数尽量多.他的同伴只会用手上的重复的交换手上没有的,并且他的同伴们之间不会产生交换.求出Bo ...
- bzoj1367
题解: 左偏树模板题 维护n/2的好多课左偏树 每一次加进来一个点的时候,只有一个点 然后每次中位数比前面小的时候,那么和前面合并 代码: #include<bits/stdc++.h> ...
- BOM之JavaScript常用事件
body, table{font-family: 微软雅黑; font-size: 10pt} table{border-collapse: collapse; border: solid gray; ...
- kill与kill -9的区别
有时候我们使用kill无法杀掉一个进程,但是用kill -9却可以,why? 首先看一下kill的功能,man手册对kill描述如下: KILL(1) Linux User's Manual KILL ...
- Redis入门简单操作
一.下载安装 Linux下载服务器版本地址:https://redis.io/download Windows下载客户端Redis Desktop Manager:https://redisdeskt ...
- tensorflow中 tf.train.slice_input_producer 和 tf.train.batch 函数
tensorflow数据读取机制 tensorflow中为了充分利用GPU,减少GPU等待数据的空闲时间,使用了两个线程分别执行数据读入和数据计算. 具体来说就是使用一个线程源源不断的将硬盘中的图片数 ...