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



10 11

input

8 30 7

output



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的更多相关文章

  1. 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 ...

  2. Codeforces Round #262 (Div. 2) 460C. Present(二分)

    题目链接:http://codeforces.com/problemset/problem/460/C C. Present time limit per test 2 seconds memory ...

  3. 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双袜子, ...

  4. 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 ...

  5. Codeforces Round #262 (Div. 2)解题报告

    详见:http://robotcator.logdown.com/posts/221514-codeforces-round-262-div-2 1:A. Vasya and Socks   http ...

  6. 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 ...

  7. Codeforces Round #262 (Div. 2)

    A #include <iostream> #include<cstdio> #include<cstring> #include<algorithm> ...

  8. Codeforces Round #262 (Div. 2) A B C

    题目链接 A. Vasya and Socks time limit per test:2 secondsmemory limit per test:256 megabytesinput:standa ...

  9. Codeforces Round #262 (Div. 2) 二分+贪心

    题目链接 B Little Dima and Equation 题意:给a, b,c 给一个公式,s(x)为x的各个位上的数字和,求有多少个x. 分析:直接枚举x肯定超时,会发现s(x)范围只有只有1 ...

随机推荐

  1. 【2016-10-17】【坚持学习】【Day8】【抽象工厂模式】

    定义: 提供一个创建一系列相关或相互依赖对象的接口,而无须指定它们具体的类. 结构: 抽象工厂类 具体工厂类 抽象产品类 具体产品类 例子: 代码: interface SkinFactory { B ...

  2. 俄罗斯方块(Java实现)

    程序效果: 代码: //Box.java 1 package tetris; public class Box { private final int M = 30, N = 12; private ...

  3. <<MySchool数据库设计优化>> 内部测试

    1) 在SQL Server 中,为数据库表建立索引能够( C ). A. 防止非法的删除操作 B. 防止非法的插入操作 C. 提高查询性能 D. 节约数据库的磁盘空间 解析:索引的作用是通过使用索引 ...

  4. 解决Scala Play框架在Git Bash运行的异常:Could not find configuration file ../framework/sbt/sbt.boot.properties

    Git Bash+ConEmu可以模拟Linux强大的命令行.不过在结合Scala和Play时,需要注意如下事项: 1. Scala的安装在64位操作系统下,默认会放在“C:\Program File ...

  5. 物联网平台设计心得:DateTimePicker实现选择联动

    所谓的选择联动,就是指,当我DateTimePicker1选择2月4号的时候,我DateTimePicker2只能选择2月4号和2月5号两天,当然你可以自行规定要选择的日期.这在一些图表查询条件里面是 ...

  6. js通过日期计算属于星期几

    var arys1 = new Array(); arys1 = "2016-09-25".split('-'); //日期为输入日期,格式为 2013-3-10 var ssda ...

  7. linux perf - 性能测试和优化工具

    Perf简介 Perf是Linux kernel自带的系统性能优化工具.虽然它的版本还只是0.0.2,Perf已经显现出它强大的实力,足以与目前Linux流行的OProfile相媲美了. Perf 的 ...

  8. mysql忘记root密码解决办法

    最近项目中的数据库我放在了服务器上,但是今天突然不能用了,进入服务器查看,果然是数据库不能进去了,所以今天来分享一个mysql忘记root密码的解决方案: 1.让mysql不载入权限表,命令:mysq ...

  9. Android进程保活

    Android进程回收机制 Low Memory Killer原理 微信团队原创分享:Android版微信后台保活实战分享(网络保活篇) 微信团队原创分享:Android版微信后台保活实战分享(进程保 ...

  10. oracle普通用户登录em

    刚新创建一个用户,登陆EM(Enterprise Manager) 如下提示: 应用程序要求的数据库权限超出了您当前具有的权限.有关特定版本的详细信息, 解决办法: 给登陆用户赋予 select_ca ...