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& ...
随机推荐
- springboot p6spy 打印完整sql
调试时打印出sql的需求,太正常不过了,mybatis也提供了这样的功能: mybatis: configuration: log-impl: org.apache.ibatis.logging.st ...
- 《Effective C#》读书笔记——条目13:正确地初始化静态成员变量<.NET资源管理>
我们知道在C#语言中创建一个类型的实例前,就应该初始化该类型的所有静态成员变量.C#语言为我们提供了静态初始化器和静态构造函数.其中,静态构造函数是一个特殊的构造函数,将在其他所有方法执行前以及变 ...
- Tornado源码分析 --- Etag实现
Etag(URL的Entity Tag): 对于具体Etag是什么,请求流程,实现原理,这里不进行介绍,可以参考下面链接: http://www.oschina.net/question/234345 ...
- Hive之GROUP BY详解
一,GROUP BY 执行理解 先来看下表1,表名为test: 表1 执行如下SQL语句: SELECT name from test GROUP BY name ; 你应该很容易知道运行的结果, ...
- POJ 1321 棋盘问题 dfs 难度:0
http://poj.org/problem?id=1321 注意是在'#'的地方放棋子 矩阵大小不过8*8,即使是8!的时间复杂度也足以承受,可以直接dfs求解 dfs时标注当前点的行和列已被访问, ...
- Python3 元组Tuple(十二)
元组:tuple.tuple和list非常类似,但是tuple一旦初始化就不能修改 元组使用小括号,列表使用方括号. 元组创建很简单,只需要在括号中添加元素,并使用逗号隔开即可. 如下实例: tup1 ...
- Java实现冒泡排序,选择排序,插入排序
冒泡排序: 思想: 冒泡排序重复地走访过要排序的数列,一次比较两个元素,如果他们的顺序错误就把他们交换过来.走访数列的工作是重复地进行直到没有再需要交换,也就是说排序完成 特点:比较稳定,排序数较小是 ...
- fiddler手机端抓包配置
首先,你得安装fiddler,这是前提条件,手机抓包有必须条件: 需要保持电脑和手机在同一个局域网中 (这一点,我一般会在电脑上启动一个wifi,然后手机连接即可) 下面说一下如何配置: 手机连接电脑 ...
- Robot Framework中使用HttpLibrary教程and中文支持
Robot Framework中使用and转参数时,默认不支持中文模式,如图场景: 会出现这种错误 FAIL : UnicodeDecodeError: 'ascii' codec can't dec ...
- c++的c风格字符串函数的实现
要注意使用断言判断传入的字符串非空. #include <cassert> //求字符串长度 size_t StrLen(const char *str) { assert(str != ...