【codeforces 768C】Jon Snow and his Favourite Number
【题目链接】:http://codeforces.com/contest/768/problem/C
【题意】 
 
给你n个数字; 
让你每次把这n个数字排序; 
然后对奇数位的数字进行异或操作,然后对新生成的序列再重复上述操作总共k次; 
问最后的序列的最小值和最大值分别是多少;
【题解】 
 
可以用计数排序来搞; 
因为数字最大为1000; 
所以将近O(K*1000)的复杂度; 
完全可以的; 
每次从小到大(0到1000(枚举数字; 
然后根据该数字的个数判断该数字有几个数字要进行异或,几个数字保持原样. 
然后在新的计数排序数组里面记录一下就好; 
最后一遍循环搞出最大最小值就好; 
 
【完整代码】
#include <bits/stdc++.h>
using namespace std;
#define lson l,m,rt<<1
#define rson m+1,r,rt<<1|1
#define LL long long
#define rep1(i,a,b) for (int i = a;i <= b;i++)
#define rep2(i,a,b) for (int i = a;i >= b;i--)
#define mp make_pair
#define pb push_back
#define fi first
#define se second
#define rei(x) scanf("%d",&x)
#define rel(x) scanf("%lld",&x)
typedef pair<int,int> pii;
typedef pair<LL,LL> pll;
const int dx[9] = {0,1,-1,0,0,-1,-1,1,1};
const int dy[9] = {0,0,0,-1,1,-1,1,-1,1};
const double pi = acos(-1.0);
const int N = 1e3+500;
int n,k,xx;
int bo[2][N];
int main()
{
    //freopen("F:\\rush.txt","r",stdin);
    rei(n),rei(k),rei(xx);
    rep1(i,1,n)
    {
        int y;
        rei(y);
        bo[0][y]++;
    }
    int now = 0;
    rep1(i,1,k)
    {
        rep1(j,0,1100)
            bo[1-now][j] = 0;
        int x = 0;
        rep1(j,0,1100)
            if (bo[now][j]>0)
            {
                int ju = bo[now][j]&1;
                if (x==0)
                {
                    if (ju)
                    {
                        bo[1-now][j^xx]+=((bo[now][j]+1)/2);
                        bo[1-now][j]+=(bo[now][j]-((bo[now][j]+1)/2));
                        x = 1;
                    }
                    else
                    {
                        bo[1-now][j^xx]+=bo[now][j]/2;
                        bo[1-now][j]+=(bo[now][j]-(bo[now][j]/2));
                        x = 0;
                    }
                }
                else
                {
                    if (ju)
                    {
                        bo[1-now][j^xx]+=((bo[now][j]-1)/2);
                        bo[1-now][j]+=(bo[now][j]-((bo[now][j]-1)/2));
                        x = 0;
                    }
                    else
                    {
                        bo[1-now][j^xx]+=((bo[now][j])/2);
                        bo[1-now][j]+=(bo[now][j]-((bo[now][j])/2));
                        x = 1;
                    }
                }
            }
        now = 1-now;
    }
    rep2(i,1100,0)
        if (bo[now][i]>0)
        {
            printf("%d ",i);
            break;
        }
    rep1(i,0,1100)
        if (bo[now][i]>0)
        {
            printf("%d\n",i);
            break;
        }
    return 0;
}【codeforces 768C】Jon Snow and his Favourite Number的更多相关文章
- codeforces 768 C. Jon Snow and his Favourite Number(思维+暴力)
		题目链接:http://codeforces.com/contest/768/problem/C 题意:给出n个数,k个操作,和一个x,每次操作先排序然后对奇数位数进行xor x操作,最后问k次操作后 ... 
- Divide by Zero 2017 and Codeforces Round #399 (Div. 1 + Div. 2, combined) C - Jon Snow and his Favourite Number
		地址:http://codeforces.com/contest/768/problem/C 题目: C. Jon Snow and his Favourite Number time limit p ... 
- Codeforces768C Jon Snow and his Favourite Number                                                                                            2017-02-21 22:24             130人阅读              评论(0)              收藏
		C. Jon Snow and his Favourite Number time limit per test 4 seconds memory limit per test 256 megabyt ... 
- 【codeforces 768D】Jon and Orbs
		[题目链接]:http://codeforces.com/contest/768/problem/D [题意] 你有一个水晶; 它每天都会产生一个球??(球有k种) 然后每种球产生的可能性是相同的-& ... 
- 【Codeforces 947B】 Producting Snow
		[题目链接] 点击打开链接 [算法] 前缀和 + 堆 [代码] #include<bits/stdc++.h> using namespace std; typedef long long ... 
- 【基数排序】Divide by Zero 2017 and Codeforces Round #399 (Div. 1 + Div. 2, combined) C. Jon Snow and his Favourite Number
		发现值域很小,而且怎么异或都不会超过1023……然后可以使用类似基数排序的思想,每次扫一遍就行了. 复杂度O(k*1024). #include<cstdio> #include<c ... 
- codeforces 768c Jon Snow And His Favourite Number
		题意: 给出一个数列,和一种操作,以及两个数x和k. 这个操作有两个步骤: 首先把这个数列按照升序排序,然后把所有奇数位上的数字与x异或. 问执行k次操作之后,这个数列的最大值和最小值是多少. 思路: ... 
- CodeForces - 768C Jon Snow and his Favourite Number 桶排
		https://vjudge.net/problem/CodeForces-768C 题意:n个数,k次操作,x.每次操作先排序,再让奇数位置上的数据a[i]:=a[i] XOR x; k< ... 
- Jon Snow and his Favourite Number CodeForces - 768C (技巧)
		链接 题意 给定数组, 每次操作先将数组排序, 再将奇数位全部异或x, 求k次操作后数组最大值与最小值 (1 ≤ n ≤ 105, 0 ≤ k ≤ 105, 0 ≤ x ≤ 103) 题解 直接暴力模 ... 
随机推荐
- dot 语法全介绍
			0. 保存 保存为 pdf:dot -Tpdf iris.dot -o iris.pdf 1. 基本 (1)无向图.有向图.子图 graph G {} // 无向图 digraph G {} // 有 ... 
- 原生js大总结十
			91.ajax的优点 a.提高运行效率 b.提高用户体验,让多件事情同时发生 c.在不刷新页面的情况下可以对局部数据进行加载和刷新 92.ajax请求的流程 1.创建通 ... 
- 洛谷 P1601 A+B Problem(高精)
			P1601 A+B Problem(高精) 题目背景 无 题目描述 高精度加法,x相当于a+b problem,[b][color=red]不用考虑负数[/color][/b] 输入输出格式 输入格式 ... 
- 魅族MX5和努比亚布拉格手机參数对照
			想买个Android手机锁定魅族MX5和努比亚布拉格.两个官网翻来翻去的非常难取舍,自己列了一个表对比了一下參数,本人喜欢薄一点的手机.有feel.參数对比表例如以下: 手机 魅族MX5 努比亚布拉格 ... 
- usr/bin/mysqladmin: refresh failed; error: 'Unknown error'
			debian wheezy 升级后, 由于授权错误, 导致password给改动, 在debian的mysql safe下也无法进入. 我在/etc/mysql/my.cnf 里面已经改动了bin ... 
- LaTeX indicator function(指示函数)(\mathbb {1} 不起作用)
			问题说明: \mathbb字符的空心化显示仅对字符有效,对数字无效. 解决方法: 使用 bbm 包 \documentclass{article} \usepackage{bbm} \begin{do ... 
- regexp模式匹配+location页面跳转+cookie/localstorage本地存储
			学习js的过程中,根据知识点编写一些code进行测试,以便检验. 这段程序使用了以下知识点: 1.regexp,对数据进行模式匹配 2.使用location对象进行页面跳转. 3.cookie/loc ... 
- (转)kvm虚拟机中,如何给子系统更换光盘
			转自:http://www.cnblogs.com/york-hust/archive/2012/06/12/2546334.html 启动kvm后,在kvm窗口中,按下CTRL+ALT+2,切换至q ... 
- linux查找keyword在php出现的次数
			查找CleverCode在当前文件夹以及子文件夹,全部的php出现大于0的次数. # find -type f -name '*.php' | xargs grep CleverCode ./*.ph ... 
- SpringBoot application.yml logback.xml,多环境配置,支持 java -jar --spring.profiles.active(转)
			趁今天有时间整理了一下 启动命令为 //开发环境 java -jar app.jar --spring.profiles.active=dev--server.port=8060 //测试环境 jav ... 
