Codeforces Round #262 (Div. 2) 1004
Codeforces Round #262 (Div. 2) 1004
D. Little Victor and Set
time limit per test
1 second
memory limit per test
256 megabytes
input
standard input
output
standard output
Little Victor adores the sets theory. Let us remind you that a set is a group of numbers where all numbers are pairwise distinct. Today Victor wants to find a set of integers S that has the following properties:
for all x

the following inequality holds l ≤ x ≤ r;
1 ≤ |S| ≤ k;
lets denote the i-th element of the set S as si; value

must be as small as possible.
Help Victor find the described set.
Input
The first line contains three space-separated integers l, r, k (1 ≤ l ≤ r ≤ 1012; 1 ≤ k ≤ min(106, r - l + 1)).
Output
Print the minimum possible value of f(S). Then print the cardinality of set |S|. Then print the elements of the set in any order.
If there are multiple optimal sets, you can print any of them.
Sample test(s)
input
8 15 3
output
1
2
10 11
input
8 30 7
output
0
5
14 9 28 11 16
Note
Operation

represents the operation of bitwise exclusive OR. In other words, it is the XOR operation.
【分析】很显然的结论,K^(K+1)=1,其中K是偶数。当K>3时,我们可以选连续的4个自然数使异或和为0。(当然注意要特判R-L+1的大小)。当K=1时,就是L。当K=2时,显然只能构造异或为1的情况。
所有的推论都指向一个问题:当K=3的一般情况怎么做?
【题解】对于那个情况,我一直觉得能贪心构造,但是怎么也想不出简单易行且效率高的算法。
其实很简单。我们设L<=X<Y<Z<=R,然后来贪心构造他们。
在二进制中,异或和为0的情况是1,1,0或0,0,0。显然Z的第一位是1,然后X和Y是0。
因为是贪心,我们要尽量使Y靠近Z(因为如果Z符合范围,Y显然越大越好)。
那么第二位我们就让Y靠近Z。我们把Z那位设成0,X和Y都设成1,即如下形式:
110000000
101111111
011111111
wa了很多次,
1.没有用long long
2.只有l^(l+1) l为偶数时,才能异或值为1
3.当k>=4但是不存在4个数异或为0的时候,没考虑3个也可能为0
4.1<<35超过int 得写成(long long)1<<35
5.当2个异或不是1时,应该判断他的值和l的大小
#include <cstring>
#include <iostream>
#include <algorithm>
#include <cstdio>
#include <cmath>
#include <map>
#include <cstdlib>
#define M(a,b) memset(a,b,sizeof(a))
#define INF 0x3f3f3f3f
using namespace std;
long long l,r,k;
int main()
{
scanf("%I64d%I64d%I64d",&l,&r,&k);
if(k==) printf("%I64d\n1\n%I64d\n",l,l);
else if(k==)
{
if(l%==)
printf("1\n2\n%I64d %I64d\n",l,l+);
else if(l+<=r)
printf("1\n2\n%I64d %I64d\n",l+,l+);
else if(((l)^(l+))<l) {
//cout<<(((l)^(l+1))-l)<<endl;
printf("%I64d\n2\n%I64d %I64d\n",(l)^(l+),l,l+);
}
else printf("%I64d\n1\n%I64d\n",l,l);
}
else if(k>=)
{
if(l%==)
printf("0\n4\n%I64d %I64d %I64d %I64d\n",l,l+,l+,l+);
else if(l+<r)
printf("0\n4\n%I64d %I64d %I64d %I64d\n",l+,l+,l+,l+);
else if(((l)^(l+)^(l+)^(l+))==)printf("0\n4\n%I64d %I64d %I64d %I64d\n",l,l+,l+,l+);
else
{
int count1 = ;
long long tem1 = r;
while(tem1>)
{
tem1 = tem1>>;
count1++;
}
//cout<<count1<<endl;
int cnt = ;
long long ans1 = ;
long long ans2 = ;
for(int i = count1-;i>=;i--)
{
if(((r>>i)&)==)
{
if(cnt == )
{
ans1 = ans1|((long long)<<i);
cnt++;
}
else if(cnt >= )
{
ans2 = ans2|((long long)<<i);
cnt++;
}
}
else
{
if(cnt>)
{
ans1 = ans1|((long long)<<i);
ans2 = ans2|((long long)<<i);
}
}
}
if(ans2<l)
{
if(l%==)
printf("1\n2\n%I64d %I64d\n",l,l+);
else printf("1\n2\n%I64d %I64d\n",l+,l+);
}
else printf("0\n3\n%I64d %I64d %I64d\n",ans1,ans2,r);
}
}
else
{
int count1 = ;
long long tem1 = r;
while(tem1>)
{
tem1 = tem1>>;
count1++;
}
//cout<<count1<<endl;
int cnt = ;
long long ans1 = ;
long long ans2 = ;
for(int i = count1-;i>=;i--)
{
if(((r>>i)&)==)
{
if(cnt == )
{
ans1 = ans1|((long long)<<i);
cnt++;
}
else if(cnt >= )
{
ans2 = ans2|((long long)<<i);
cnt++;
}
}
else
{
if(cnt>)
{
ans1 = ans1|((long long)<<i);
ans2 = ans2|((long long)<<i);
}
}
//cout<<ans2<<' '<<ans1<<endl;
}
//cout<<ans2<<' '<<ans1<<endl;
if(ans2<l)
{
if(l%==)
printf("1\n2\n%I64d %I64d\n",l,l+);
else printf("1\n2\n%I64d %I64d\n",l+,l+);
}
else printf("0\n3\n%I64d %I64d %I64d\n",ans1,ans2,r);
}
return ;
}
Codeforces Round #262 (Div. 2) 1004的更多相关文章
- Codeforces Round #262 (Div. 2) 1003
Codeforces Round #262 (Div. 2) 1003 C. Present time limit per test 2 seconds memory limit per test 2 ...
- Codeforces Round #262 (Div. 2) 460C. Present(二分)
题目链接:http://codeforces.com/problemset/problem/460/C C. Present time limit per test 2 seconds memory ...
- codeforces水题100道 第十五题 Codeforces Round #262 (Div. 2) A. Vasya and Socks (brute force)
题目链接:http://www.codeforces.com/problemset/problem/460/A题意:Vasya每天用掉一双袜子,她妈妈每m天给他送一双袜子,Vasya一开始有n双袜子, ...
- Codeforces Round #262 (Div. 2) E. Roland and Rose 暴力
E. Roland and Rose Time Limit: 1 Sec Memory Limit: 256 MB 题目连接 http://codeforces.com/problemset/pro ...
- Codeforces Round #262 (Div. 2)解题报告
详见:http://robotcator.logdown.com/posts/221514-codeforces-round-262-div-2 1:A. Vasya and Socks http ...
- Codeforces Round #262 (Div. 2)460A. Vasya and Socks(简单数学题)
题目链接:http://codeforces.com/contest/460/problem/A A. Vasya and Socks time limit per test 1 second mem ...
- Codeforces Round #262 (Div. 2)
A #include <iostream> #include<cstdio> #include<cstring> #include<algorithm> ...
- Codeforces Round #262 (Div. 2) A B C
题目链接 A. Vasya and Socks time limit per test:2 secondsmemory limit per test:256 megabytesinput:standa ...
- Codeforces Round #262 (Div. 2) 二分+贪心
题目链接 B Little Dima and Equation 题意:给a, b,c 给一个公式,s(x)为x的各个位上的数字和,求有多少个x. 分析:直接枚举x肯定超时,会发现s(x)范围只有只有1 ...
随机推荐
- 《InsideUE4》-7-GamePlay架构(六)PlayerController和AIController
PlayerController:你不懂,伴君如伴虎啊 AIController:上来,我自己动 引言 上文我们谈到了Component-Actor-Pawn-Controller的结构,追溯了ACo ...
- 【问题&解决】fonts/fontawesome-webfont.woff2 404 (Not Found)
问题: 虽然网页正常显示和运行,但是有2个字体文件出现404错误.像笔者这种强迫症是接受不了的. 解决: 因为笔者的服务器是虚拟主机,只需要在主机控制器平台添加对应的MIME类型即可. 这样服务器就支 ...
- 纯java配置SpringMVC
一般情况下,我们会在web.xml下配置好Spring和SpringMVC,并指定好它们的配置文件 是最常用的也是最方便的方法 例如: web.xml <!-- The definition o ...
- 关于webpack编译scss文件
css加载器文件通常和extract-text-webpack-plugin一块使用,我们可以在源文件src目录下写scss文件,然后通过webpack编译成css文件到输出目录public,这个目录 ...
- iOS通知
链接: IOS之推送通知(本地推送和远程推送) iOS 10推送通知开发 活久见的重构 - iOS 10 UserNotifications 框架解析 iOS10全新推送功能的实现
- VS 常用高效 快捷键
强迫智能感知:Ctrl+J.智能感知是Visual Studio最大的亮点之一,选择Visual Studio恐怕不会没有这个原因. 2 撤销:Ctrl+Z.除非你是天才,那么这个快捷键也是最常用的. ...
- Swift语言学习
因为想要学Mac os x编程,中文教材太少了,看了很多厉害的英文教材,很多都是swift语言的了,所以决定先要大体学一下swift语言. 学习一门语言,第一件事看swift官方文档,这里附上Coco ...
- PHP引用(&)使用详解
初学php关于&引用 官方文档: 1.引用是什么:http://www.php.net/manual/zh/language.references.whatare.php 2.引用做什么:ht ...
- SqlMetal.exe ORM代码生成
作甚? 先说说这个工具是干啥的,我们所做的程序,或多或少需要存储一些数据到数据库,当然直接使用Sql语句也可以,甚至有些情况下就是要使用sql语句,但对于一些基本的增删改查,对每张表都要写查询语句就显 ...
- C语言编程实现Linux命令——who
C语言编程实现Linux命令--who 实践分析过程 who命令是查询当前登录的每个用户,它的输出包括用户名.终端类型.登录日期及远程主机,在Linux系统中输入who命令输出如下: 我们先man一下 ...