【CF】Round #618 div2 C(文末有技巧)
round #618 div2 C(文末有技巧)
这是题目链接->链接
题目:
原题目是全英文的,所以我就粗略来翻译一下:
有这样一个函数f:f(x,y)=(x|y)-y;(其中|是按位或操作)
比如说:f(11,6)=(11|6)-6=15-6=9;(简单明了)
现在有一个数组 [a1,a2,…,an],让你求f(f(…f(f(a1,a2),a3),…an−1),an) ,数组中可能有相同的数字,让你对这个数组重新排序,以保证最终的结果是最大。(如果有多个答案,输出任意一种即可)
样例输入输出
输入
第一行输入一个n(1≤n≤10^5).
第二行输入n个数,a1,a2,…,an (0≤ai≤10^9).
输出
输出n个数,最后结果是最大的数组顺序,如果有多个答案,任意输出一种。
样例输入
4
4 0 11 6
样例输出
11 6 4 0
样例输入
1
13
样例输出
13
思路
我就不说我的思路了(萌新思路),官方题解+正规解答是这个样子的:
首先观察题目函数f(11,6)=11|6-6,既然是关于位操作的,那么来一波二进制运算:
11:1011
6:0110
ans:1001
~6:1001
最后经过大佬的慧眼(不是我),得出结论为
f(x|y)=(x|y)-y=x&(~y)!!!
ps:
~为取反操作,1变0,0变1,如0110(6),1001(~6)
&为按位与操作,有0则0,无0则1,如1011(11)&1001(~6)=1001
所以[a1,a2,…,an]就变成了a1&(~a2)&(~a3)....&(~an);
根据官方题解来讲a1对答案贡献最大(我觉得a1最为特殊),找到a1,其他的依次输出就可以了,找不到就原序输出;
那么问题来了,如何找到那个扛把子a1?
据大佬口述,只需要找到最高位的1在谁那,谁就是扛把子
那么思路油然而生️:
从最高位二进制最高位遍历每个数,一旦找到一个,就是a1,把它首先输出,再把其它的数依次输出,如果找不到,就原序输出:
#include <iostream>
#include <cstdio>
#define N 100005
using namespace std;
//@date: 2020-02-10 11:28:12
//@state:Yes
//@purpose:bitmasking(位屏蔽)
inline void read(int &x){
//快速读取int
int ch = getchar(); x = 0;
bool f = false;
while((ch < '0' || ch > '9') && ch != '-') ch = getchar();
if(ch == '-'){f = true; ch = getchar();}
while(ch >= '0' && ch <= '9'){x = x * 10 + ch - '0'; ch = getchar();}
if(f) x = -x;
}
int a[N],c[N];
int main()
{
int n;
read(n);
for(register int i=1;i<=n;i++)
read(a[i]);
for(register int j=30;j>=0;j--)
{
int cnt=0,p;
for(register int i=1;i<=n;i++)
if((a[i]>>j)&1)//把a[i]右移j位就是取a[i]的第j+1位二进制数,看是否是1}
cnt++,p=i;
if(cnt==1)
{
cout<<a[p]<<" ";//输出扛把子a1
for(register int k=1;k<=n;k++)
{//输出其他的
if(k!=p)
cout<<a[k]<<" ";
}
return 0;
}
}
//没找到扛把子的情况,就原序输出
for(register int i=1;i<=n;i++)
cout<<a[i]<<" ";
return 0;
}
小技巧(拿小本本记下来)
- 快速读取数字,实测比最快的scanf还要快!
inline void read(int &x){
int ch = getchar(); x = 0;
bool f = false;
while((ch < '0' || ch > '9') && ch != '-') ch = getchar();
if(ch == '-'){f = true; ch = getchar();}
while(ch >= '0' && ch <= '9'){x = x * 10 + ch - '0'; ch = getchar();}
if(f) x = -x;
}
- 二进制的遍历
有人可能会问,为什么遍历二进制数j要从30开始,到0呢?
且听我细细道来~
首先int类型(指有符号整型),现在都是4字节32位了,所以范围就是-2^32 -1到2^32-1,也就是说最长为31位,剩下一位表示正负,我们不用管。
我们想要的就是从二进制最高位去遍历
而右移>>符号的意思正好满足我们获取最高位的功能
比如说:1011(11)
11>>3=1011(1),现在右移3位得到的就是第4位二进制数。
- bitmasking(位屏蔽)
位屏蔽的含义是从包含多个位集的一个或一组字节中选出指定的一(些)位。为了检查一个字节中的某些位,可以让这个字节和屏蔽字(bit mask)进行按位与操作(C的按位与运算符为&)——屏蔽字中与要检查的位对应的位全部为1,而其余的位(被屏蔽的位)全部为0。
以上是来自百度回答,这个名词百度百科中没有,但是我觉得这个回答很好。
但是你们是不是看的头疼啦(是的,啥也没看懂-.-),简而言之,取出二进制数的特定位来操作。
放在这道题上就是取出a[i]的第j+1位二进制数判断是否是1,用代码来说就是这个地方:
if((a[i]>>j)&1)//把a[i]右移j位就是取a[i]的第j+1位二进制数,看是否是1}
- 使用频繁的变量放在寄存器
register int的register表示使用cpu内部寄存器(寄存器是中央处理器内的组成部分。寄存器是有限存贮容量的高速存贮部件)的变量,而平时的int是把变量放在内存中,存到寄存器中可以加快变量的读写速度)
for(register int i=1;i<=n;i++)
read(a[i]);
现在有人说C++最新标准已经不认这个了,反正我自己使用做对比仍有提升(现在时间2020.2.10),在多重循环中颇有奇效!!!嘘~这是我从这次比赛榜一的代码中学到的,自己知道就行了️
【CF】Round #618 div2 C(文末有技巧)的更多相关文章
- CF Round #580(div2)题解报告
CF Round #580(div2)题解报告 T1 T2 水题,不管 T3 构造题,证明大约感性理解一下 我们想既然存在解 \(|a[n + i] - a[i]| = 1\) 这是必须要满足的 既然 ...
- CF round #622 (div2)
CF Round 622 div2 A.简单模拟 B.数学 题意: 某人A参加一个比赛,共n人参加,有两轮,给定这两轮的名次x,y,总排名记为两轮排名和x+y,此值越小名次越前,并且对于与A同分者而言 ...
- [CF Round #295 div2] C. DNA Alignment 【观察与思考0.0】
题目链接:C. DNA Alignment 题目大意就不写了,因为叙述会比较麻烦..还是直接看英文题面吧. 题目分析 经过观察与思考,可以发现,构造的串 T 的每一个字符都与给定串 S 的每一个字符匹 ...
- [CF Round #294 div2] E. A and B and Lecture Rooms 【树上倍增】
题目链接:E. A and B and Lecture Rooms 题目大意 给定一颗节点数10^5的树,有10^5个询问,每次询问树上到xi, yi这两个点距离相等的点有多少个. 题目分析 若 x= ...
- [CF Round #294 div2] D. A and B and Interesting Substrings 【Map】
题目链接:D. A and B and Interesting Substrings 题目大意 给定26个小写字母的权值,一共26个整数(有正有负). 给定一个小写字母组成的字符串(长度10^5),求 ...
- A. Grasshopper And the String(CF ROUND 378 DIV2)
A. Grasshopper And the String time limit per test 1 second memory limit per test 256 megabytes input ...
- A. Alyona and Numbers(CF ROUND 358 DIV2)
A. Alyona and Numbers time limit per test 1 second memory limit per test 256 megabytes input standar ...
- CF Round#436 div2
额,这次的题目其实挺智障的.所以通过这次比赛,我也发现了自己是一个智障.... 不说太多,说多是泪... A. Fair Game 题意:给你一个数组,看你能否把它均分为两个所有元素均相同的子数组. ...
- CF Round #569 Div2(contest1180)
比赛链接:http://codeforces.com/contest/1180 Problem A 题意:给出n,问方块数.看图理解... Solution: 找一找规律就可以了,发现方块数为2n*( ...
- CF Round #687 Div2 简要题解
题面 A 可以发现,最远的几个人一定是 \((1, 1), (1, m), (n, 1), (n, m)\) 中的一个,直接计算即可. B 注意到颜色数量很少,直接暴力枚举最终的颜色后模拟即可. C ...
随机推荐
- (1)入门MasaFramework教程
(1)入门MasaFramework教程 首先了解一下MasaFramework是什么 MasaFramework是一个基于.Net6.0的后端框架, 可以被用于开发Web应用程序.WPF项目.控制台 ...
- 前端程序员需要了解的MySQL
数据库的基本概念 数据库(database)是用来组织.存储和管理数据的仓库.对数据库中的数据可以进行增删改查操作.市面上常见的数据库有: MySQL(使用最广泛.流行度最高的开源免费数据库 Comm ...
- Android笔记--Android studio里面打开数据库详解
1.下载Database Navigator插件,然后需要重启Android studio 2.然后会总界面这里.出现这样一个图标 然后选中Database Brower: 3.弹出这样一个界面 然后 ...
- DecimalFormat--控制输出格式
DecimalFormat的相关应用 整数的实现: 小数的实现: 科学计数法: 分组分隔符: 举个例子吧!-- 关于前缀后缀: 本地化货币符号: 引用特殊的字符,作为前缀或者后缀: 实例来袭! 1.0 ...
- 使用 SpeechT5 进行语音合成、识别和更多功能
我们很高兴地宣布,SpeechT5 现在可用于 Transformers (一个开源库,提供最前沿的机器学习模型实现的开源库). SpeechT5 最初见于微软亚洲研究院的这篇论文 SpeechT5: ...
- 关于 manacher 的一个小细节
在该算法中,我们需要用到一个数组 hw[i] ,代表 i 的最大回文半径.而且这个半径不包括 i 本身(若串为 ccc 则 hw 为 1). 这时最终答案为最大的 hw 减一. 为什么要减一呢?最终的 ...
- koa中间件的实现原理
koa中间件的实现原理如何?先来看一个例子. koa的执行顺序是这样的: const middleware = async function (ctx, next) { console.log(1) ...
- SQL优化---慢SQL优化
于2023.3.17日重写,之前写的还是太八股文太烂了一点逻辑都没有,这次重新写了之后,感觉数据库优化还是很有必要的,之前觉得不必要是我年轻了. 一.如何定位慢SQL语句 1.通过慢查询日志查询已经执 ...
- 原来还能这样看Java线程的状态及转换
作者:小牛呼噜噜 | https://xiaoniuhululu.com 计算机内功.JAVA底层.面试.职业成长相关资料等更多精彩文章在公众号「小牛呼噜噜」 大家好,我是呼噜噜,最近一直在梳理Jav ...
- Qt源码阅读(三) 对象树管理
对象树管理 个人经验总结,如有错误或遗漏,欢迎各位大佬指正 @ 目录 对象树管理 设置父对象的作用 设置父对象(setParent) 完整源码 片段分析 对象的删除 夹带私货时间 设置父对象的作用 众 ...