题目大意:

给定一种函数F(x,y)=(x|y)-y,| 即按位或运算

给定一个长度为n的数组a[1],a[2],a[3]...a[n]

可以重新排列数组a,使得 F ( ...... F ( F ( a[1] , a[2] ) , a[3] ) ...... , a[n] ) 最后得到的答案最大

问这样的一个排列(答案不唯一输出任意一个)

解题思路:

首先拿到这种函数,可以去找他的规律

举例两个二进制的数

11111

01010

这两个数先进行取或运算,得到

11111

再减去第二个数,得到

10101

可以发现,这种运算的意义就是

如果在二进制中,后一个数字的第 i 位是1,那么结果中的这一位必定为0

如果在二进制中,后一个数字的第 i 位是0,那么结果中的这一位相等于前一个数字的这一位的值

因为最终答案的计算方式是把数列中每个元素都一层一层套下去

所以可以发现,对于答案的第 i 位而言,如果有大于等于两个数字,或者没有一个数字第 i 位的值为1,那么答案的第 i 位必定为0

理由为:

  1、如果没有一个数字第 i 位为1,显而易见第 i 位不可能突然冒出来一个1

  2、如果大于等于两个数字第 i 位为1,那么不论怎么这两个数(或这些数)的先后顺序,后一个数字在函数执行完后都必会把这一位变成0

所以,最终答案的二进制中一定会有一位是在所有数字内只出现过一次的(如果答案不为0)

然后还能发现,只要前面套出来的答案中第 i 位已经为0,那么后面的所有数字中不论第 i 位是0还是1,最终答案的第 i 位都是0

所以,要尽量让大的数字靠前

又因为根据二进制而言,10000一定比01111大,即最高位比较高的数字一定大

所以答案就很明显了:

  从高位往低位找,如果找到某一位只出现过一次,把这一位对应的那个数字提到数列最前端,其余数字随意排列均可,对答案不会造成影响。

以样例为例子

4 0 11 6

化为二进制即

0100

0000

1011

0110

得到(右数)第一位和第四位均只出现过一次

从最高位往最低位找,明显直接取第四位

出现的第四位为1的数是1011,即11

那么只要11出现在这个数列的头部,剩余三个任意排列,都不会改变答案的值(9)

即排列

11 0 4 6

11 0 6 4

11 4 0 6

11 4 6 0

11 6 0 4

11 6 4 0

六种排列答案相同

另外,如果没有任何一位满足要求,那么整个数组随便排列都行,因为答案必定为0

***题外话:如果此时求的是答案最大值的话,实际上也是这种求法,找到这个需要提到第一个位置的数后,检查这个数字剩余的值为1的位是不是也只出现过一次,把所有是1的只出现过一次的位提出来,就是答案。样例就是这样,第一位和第四位只出现一次的数都在1011,即11这个数上,那么答案就是把第一位和第四位取出,即1001,即9

代码为:

#include<bits/stdc++.h>
using namespace std;
int ar[],tim[],which[];
int main(){
ios::sync_with_stdio();
cin.tie();cout.tie();
int n,i,j,k;
cin>>n;
memset(tim,,sizeof tim);
for(i=;i<n;i++){
cin>>ar[i];
for(j=,k=;j<;j++){
if(ar[i]&k){
if(!tim[j])
which[j]=i;//记录第一次出现第j位为1的数
tim[j]++;
}
k<<=;
}
}
for(j=;j>=;j--){
if(tim[j]==){//这一位是所有只出现一次的1的最高位
swap(ar[],ar[which[j]]);
break;
}
}
for(i=;i<n;i++)
cout<<ar[i]<<' '; return ;
}

Codeforces 1299A/1300C - Anu Has a Function的更多相关文章

  1. Codeforces Round #618 (Div. 2)C. Anu Has a Function

    Anu has created her own function ff : f(x,y)=(x|y)−y where || denotes the bitwise OR operation. For ...

  2. Educational Codeforces Round 13 D. Iterated Linear Function 水题

    D. Iterated Linear Function 题目连接: http://www.codeforces.com/contest/678/problem/D Description Consid ...

  3. Educational Codeforces Round 13 D. Iterated Linear Function (矩阵快速幂)

    题目链接:http://codeforces.com/problemset/problem/678/D 简单的矩阵快速幂模版题 矩阵是这样的: #include <bits/stdc++.h&g ...

  4. Codeforces 221 A. Little Elephant and Function

    A. Little Elephant and Function time limit per test 2 seconds memory limit per test 256 megabytes in ...

  5. Educational Codeforces Round 13——D. Iterated Linear Function(矩阵快速幂或普通快速幂水题)

      D. Iterated Linear Function time limit per test 1 second memory limit per test 256 megabytes input ...

  6. Educational Codeforces Round 13 D. Iterated Linear Function 逆元+公式+费马小定理

    D. Iterated Linear Function time limit per test 1 second memory limit per test 256 megabytes input s ...

  7. Educational Codeforces Round 26 E - Vasya's Function

    数论题还是好恶心啊. 题目大意:给你两个不超过1e12的数 x,y,定义一个f ( x, y ) 如果y==0 返回 0 否则返回1+ f ( x , y - gcd( x , y ) ); 思路:我 ...

  8. Codeforces Round #618 (Div. 2)

    题库链接 https://codeforces.ml/contest/1300 A. Non-zero 一个数组,每次操作可以给某个数加1,让这个数组的积和和不为0的最小操作数 显然如果有0的话,必须 ...

  9. Codeforces题解集 1.0

    记录 Codeforces 2019年12月19日到 2020年2月12日 的部分比赛题 Educational Codeforces Round 82 (Rated for Div. 2) D Fi ...

随机推荐

  1. 5G时代能携号转网,你会提前换新手机吗?

    每一次网络制式的变革,总能引发业界和大众的强烈关注.毕竟网络制式的迭代,能为社会的方方面面带来极大嬗变.而5G时代即将开启,必然会出现更多弄潮儿,也会带来让人心动的美好生活.不过,鉴于5G本身的特殊性 ...

  2. maven intall 命令用法

    作用:将自定义maven项目  打成maven依赖存放到本地库,我们可以在另一个项目pom文件中加入相应依赖,刷新mavne即可将其加入项目中使用 使用说明:win+R 打开命令窗口,将目录切换至项目 ...

  3. python scipy样条插值函数大全(interpolate里interpld函数)

    scipy样条插值 scipy样条插值1.样条插值法是一种以可变样条来作出一条经过一系列点的光滑曲线的数学方法.插值样条是由一些多项式组成的,每一个多项式都是由相邻的两个数据点决定的,这样,任意的两个 ...

  4. 吴裕雄 Bootstrap 前端框架开发——Bootstrap 字体图标(Glyphicons):glyphicon glyphicon-home

    <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <meta name ...

  5. LeetCode1217 玩筹码(贪心)

    题目: 数轴上放置了一些筹码,每个筹码的位置存在数组 chips 当中. 你可以对 任何筹码 执行下面两种操作之一(不限操作次数,0 次也可以): 将第 i 个筹码向左或者右移动 2 个单位,代价为 ...

  6. HTML的文档结构与语法(二)

    3.7 超链接标记 语法:<a 属性=“值”>对当前链接的描述</a>     作用:网页进行跳转 常用的属性: Href:链接的网址或ip或地址    值:就是具体的地址 T ...

  7. 十一、JavaScript之两种注释方法

    一.代码如下 二.运行效果如下

  8. 051-PHP求余运算

    <?php $x=10%5; //进行求余运算 $y=10%3; //进行求余运算 $z=10%6; //进行求余运算 echo $x; //输出变量x的值 echo $y; //输出变量y的值 ...

  9. 139-PHP static后期静态绑定(二)

    <?php class test{ //创建test类 public function __construct(){ static::getinfo(); //后期静态绑定 } public s ...

  10. request.getParameter() 接收参数中文乱码

    修改tomcat配置文件 设置url编码集 <Connector port="8080" protocol="HTTP/1.1" connectionTi ...