D. Ehab the Xorcist(纯构造方法)
\(如果觉得下面难以理解,可以去这里看一种较为简单的解法\):saf
\(这个题嘛,首先要明确异或的性质:相同为0,不同为1.\)
\(举个例子,我们来构造u=15和v=127的情况\)
\(注意到,异或是二进制,我们把15的二进制写下来\)
\]
\(\color{Red}{说明什么?说明至少二进制的1,2,3,4位数字出现了奇数次,二进制的其他位出现了偶数次。}\)
\(你问我为什么?请看异或的定义,假如出现偶数次1相异或,仍然为0.\)
\(那么我们可以构造出最终数列中,二进制的某一位出现过多少次1.\)
\(基于贪心的思想,我们从二进制的62位开始构造。用当前的v整除{2^i}\)
\(如果在15中出现过这一位,说明我们想构造奇数次,假如除数是偶数就-1\)
\(如果在15没出现过,说明我们想构造偶数次,假如是奇数就-1\)
\(然后每一次都v都减去构造的数字\)
#include <bits/stdc++.h>
using namespace std;
typedef long long ll;
ll u,v,a[64],vis[64],ans[109],num[109],cnt,xu;
bool work()
{
ll minn=1e18,shu=0;
for(int i=1;i<=62;i++)
if(vis[i])
minn=min(minn,vis[i]);//找出出现次数最少的
if(minn==1e18) return false;//已经可以输出了
for(int i=1;i<=62;i++)
{
if(vis[i]==0) continue;
vis[i]-=minn,shu+=a[i];//都加上去
}
ans[++cnt]=shu,num[cnt]=minn,xu+=minn;
return true;
}
int main()
{
a[1]=1;
for(int i=2;i<=62;i++) a[i]=a[i-1]*2;//二进制的额每一位代表的数
cin>>u>>v;
for(int i=1;i<=62;i++)
if(u&a[i])//标记是否在u出现过
{
vis[i]=1;//出现过那么至少要有一次
v-=a[i];
}
if(v<0) cout<<-1,exit(0);
for(int i=62;i>=1;i--)
{
ll z=v/a[i];
if(z==0) continue;
if(z%2==1&&vis[i]) z--;//出现过应该构造奇数
if(z%2==1&&!vis[i]) z--;//没出现过应该构造偶数
vis[i]+=z;
v-=a[i]*z;
}
if(v!=0) cout<<-1,exit(0);
while(work()) continue;//贪心构成数字
cout<<xu<<endl;
for(int i=1;i<=cnt;i++)
for(int j=1;j<=num[i];j++)
cout<<ans[i]<<" ";
}
D. Ehab the Xorcist(纯构造方法)的更多相关文章
- D. Ehab the Xorcist
题意: 略: 感觉被演了一波,这是CFdiv2吗? 算是这个构造题吧. 1 首先我们可以将u进行二进制拆分来考虑.加入u>v那么小与v的那些数在怎么拼接也无法使异或值为u. 比如二进制U=1 0 ...
- 【题解】Ehab the Xorcist
\(\color{red}{Link}\) \(\color{blue}{\text{Solution:}}\) 题目要求构造一个最短的序列,使得异或和为\(u\),数列和为\(v\). 那么,因为是 ...
- Codeforces Round #628 (Div. 2) D. Ehab the Xorcist(异或,思维题)
题意: 寻找异或后值为 u,相加后和为 v 的最短数组. 思路: 异或得 u ,则 v 至少应大于等于 u ,且多出来的部分可以等分为两份相消. 即初始数组为 u , (v-u)/2 , (v-u)/ ...
- Codeforces Round #628 (Div. 2)
1325A - EhAb AnD gCd 题意:随意找两个数是他们的最大公约数 GCD 与最小公倍数 LCM 之和为所给定的值. 思路:找一下规律 ,假设所给的 数位n, 那么我们将n分成 1 ,n- ...
- Codeforces Round #628 (Div. 2) 题解
人闲桂花落,夜静春山空. 月出惊山鸟,时鸣春涧中.--王维 A. EhAb AnD gCd You are given a positive integer x. Find any such 2 po ...
- ios开发UI篇—使用纯代码自定义UItableviewcell实现一个简单的微博界面布局
本文转自 :http://www.cnblogs.com/wendingding/p/3761730.html ios开发UI篇—使用纯代码自定义UItableviewcell实现一个简单的微博界面布 ...
- iOS高仿app源码:纯代码打造高仿优质《内涵段子》
iOS高仿app源码:纯代码打造高仿优质<内涵段子>收藏下来 字数1950 阅读4999 评论173 喜欢133 Github 地址 https://github.com/Charlesy ...
- Spring 使用纯注解方式完成IoC
目录 创建一个简单的Person类 使用xml方式配置Spring容器并获取bean的过程 创建xml配置文件 进行测试 使用纯注解方式配置Spring容器并获取bean的过程 创建spring配置类 ...
- 牛客网刷题(纯java题型 31~60题)
牛客网刷题(纯java题型 31~60题) 重写Override应该满足"三同一大一小"三同:方法名相同,参数列表相同,返回值相同或者子类的返回值是父类的子类(这一点是经过验证的) ...
随机推荐
- mysql报错: unknown variable 'sql_mode=NO_ENGINE_SUBSTITUTION,STRICT_TRANS_TABLES'
在修改mysql默认字符集的时候: 1. 需要拷贝/usr/share/mysql下的my-huge.cnf 或者my-small.cnf到 /etc/my.cnf,但是官网说:从5.7.18开始不在 ...
- logback日志实战
<?xml version="1.0" encoding="UTF-8" ?> <!-- <configuration> < ...
- [模板]SPFA判负环
目录 一.BFS法判负环 二.DFS法判负环 三.SPFA判正环 一.BFS法判负环 Code: #include<bits/stdc++.h> #define re register # ...
- GeoGebra小制作
效果 文件链接https://www.geogebra.org/m/bkxrjymh
- Springboot系列(七) 集成接口文档swagger,使用,测试
Springboot 配置接口文档swagger 往期推荐 SpringBoot系列(一)idea新建Springboot项目 SpringBoot系列(二)入门知识 springBoot系列(三)配 ...
- H - Tempter of the Bone DFS
小明做了一个很久很久的梦,醒来后他竟发现自己和朋友在一个摇摇欲坠的大棋盘上,他们必须得想尽一切办法逃离这里.经过长时间的打探,小明发现,自己所在的棋盘格子上有个机关,上面写着“你只有一次机会,出发后t ...
- Linux服务器压力测试总结(CPU、Memory、IO等)
测试工具:sysbench.memtester.htop 1.htop安装使用 yum install ncurses-devel # 安装依赖包 tar zxvf htop-2.2.0.tar.gz ...
- Windows安装Tesseract-OCR 4.00并配置环境变量
一.前言 Tesseract-OCR 是一款由HP实验室开发由Google维护的开源OCR(Optical Character Recognition , 光学字符识别)引擎.与Microsoft O ...
- vue+element-ui中引入阿里播放器
1.在public文件下的index.html文件中插入以下代码: <link rel="stylesheet" href="https://g.alicdn.co ...
- 使用dynamic和MEF实现轻量级的AOP组件 (2)
转摘 https://www.cnblogs.com/niceWk/archive/2010/07/21/1782092.html 偷梁换柱 上一篇我们初试了DynamicAspect这把小刀,如果你 ...