https://scut.online/p/223

给定两个数N,M,构造M个在[0,80000]以内的互不相同的数使之异或和为N。

首先特判一下M<=2的两个简单情况,还有坑爹的-1!

然后想办法构造。

好像从哪里得到的启发只要把最后一次调整交给最后的数字就可以了。

但是这次调整可能会和前面生成的数字重复,这怎么搞呢?

先命令前面从1开始连续生成M-2个数字。

然后现在的异或和绝对是在10000以内的某个数,或许是0。是0那就麻烦了,就要避免,避免的方法就是最后一次生成的时候多搞一个1。那么现在cur不为0了。最多也是生成到10000多个零头。

然后生成一个(1<<14)|cur,前面就多了一个1,后面全部被搞成0,这个数字这么大肯定也没出现过。

最后异或上N就可以回答了?前面多了一个1唯一能重复的就是和倒数第二个数(1<<14)|cur重复,这种情况就是N为0的时候导致最后要异或一个一样的来取消。

所以在进行这些之前先判断N是不是0?假如是的话,倒数第二个就生成(1<<14),这下异或了之后就是前面一个1,后面跟一串非0的数字cur,最后把他们一起取消掉,肯定也比(1<<14)要大。所以是合法的。

此方法构造需要在[0,32768]以内。

#include<bits/stdc++.h>
using namespace std;
typedef long long ll; inline ll read() {
ll x = 0;
//int f = 0;
char c;
do {
c = getchar();
/*if(c == '-')
f = 1;*/
} while(c < '0' || c > '9');
do {
x = (x << 3) + (x << 1) + c - '0';
c = getchar();
} while(c >= '0' && c <= '9');
//return f ? -x : x;
return x;
} inline void _write(int x) {
if(x > 9)
_write(x / 10);
putchar(x % 10 + '0');
} inline void write(int x) {
if(x < 0) {
putchar('-');
x = -x;
}
_write(x);
putchar('\n');
} void TestCase(int ti); int main() {
#ifdef Yinku
freopen("Yinku.in", "r", stdin);
//freopen("Yinku.out","w",stdout);
#endif // Yinku
int T = 1;
for(int ti = 1; ti <= T; ti++)
TestCase(ti);
} /*--- ---*/ void TestCase(int ti) {
int N,M;
while(~scanf("%d%d",&N,&M)){
if(M==1){
printf("%d\n",N);
}
else if(M==2){
if(N==0){
puts("-1");
}
else{
printf("0 %d\n",N);
}
}
else{
int cur=0;
int id=0;
for(int i=1;i<=M-3;i++){
printf("%d ",id);
cur^=id;
id++;
}
while((cur^id)==0)
id++;
printf("%d ",id);
cur^=id; if(N==0){
printf("%d ",(1<<14));
cur^=(1<<14);
printf("%d\n",cur^N);
}
else{
printf("%d ",(1<<14)|cur);
cur^=(1<<14)|cur;
printf("%d\n",cur^N);
}
}
}
}

SCUT - 223 - Maya - 构造的更多相关文章

  1. 前端开发必备之MDN文档

    想下载MDN文档的看前面的内容就可以了. HTML 源码下载 MDN官方下载地址:https://developer.mozilla.org/media/developer.mozilla.org.t ...

  2. SCUT - 261 - 对称与反对称 - 构造 - 简单数论

    https://scut.online/p/261 由于M不是质数,要用扩展欧几里得求逆元,而不是费马小定理! 由于M不是质数,要用扩展欧几里得求逆元,而不是费马小定理! 由于M不是质数,要用扩展欧几 ...

  3. Maya 与 Matlab 数据互联插件使用教程

    实验室做网格处理方面的算法,写界面很麻烦,所以有了利用maya和matlab进行数据连通的念头,于是有了这个插件. 这个插件可以把maya的网格数据导入matlab之中,完成计算之后重新返回maya. ...

  4. maya user guider第一课,一些基本概念

    1.maya主要用于建模,动画, 视觉特效,游戏, 和模拟 一般分为以下几类: l  建模: ploygons, nurbs, subdivision surfaces   这是不同的建模方法. po ...

  5. 第1部分: 游戏引擎介绍, 渲染和构造3D世界

    原文作者:Jake Simpson译者: 向海Email:GameWorldChina@myway.com ---------------------------------------------- ...

  6. Scut:GameWebSocketHost 解析

    想使用 Scut 做的是一个短连接项目,所以先直接看 GameWebSocketHost 了. 先来看下 GameWebSocketHost 的成员: protected bool EnableHtt ...

  7. CF45G Prime Problem 构造+数论

    正解:构造+数论 解题报告: 传送门! maya这题好神仙啊我jio得,,,反正我当初听的时候是没有太懂的,,, 首先这题你要知道一些必要的数学姿势 比如哥德巴赫猜想巴拉巴拉的 然后直接讲题趴QAQ ...

  8. Scut游戏服务器引擎6.1.5.6发布,直接可运行,支持热更新

    1. 增加exe版(console),web版本(IIS)的游戏服宿主程序 2. 增加Model支持脚本化,实现不停服更新 3. 增加Language支持脚本化 4. 修改Sns与Pay Center ...

  9. 将MPM雪模拟移植到Maya

    同事实现了一个迪士尼的MPM雪模拟论文,我将其移植到Maya中 论文题目是 A material point method for snow simulation 代码在这里: https://git ...

随机推荐

  1. linux学习-环境变量与文件查找

  2. Codeforces 351B Jeff and Furik:概率 + 逆序对【结论题 or dp】

    题目链接:http://codeforces.com/problemset/problem/351/B 题意: 给你一个1到n的排列a[i]. Jeff和Furik轮流操作,Jeff先手. Jeff每 ...

  3. jQuery绑定事件的四种方式区别

    jQuery中提供了四种事件监听方式,分别是bind.live.delegate.on,对应的解除监听的函数分别是unbind.die.undelegate.off.在开始看他们之前 一:bind(t ...

  4. TinkPHP 简单知识摘要

    1.Session处理 赋值:session('name','value'); //设置session 与 $_SESSION['think']['name'] = 'value';相等 取值:$va ...

  5. MyEclipse消除frame引起的the file xxx cannot be found

    因为该页面所指向的页面路径不对,便进行手动修改,修改时却出现了很烦的问题,输入一个字就弹出一个提示框“the file XXX can not be found.Please check the lo ...

  6. [转载]C++Assert()函数

    assert宏的原型定义在<assert.h>中,其作用是如果它的条件返回错误,则终止程序执行,原型定义: #include <assert.h> void assert( i ...

  7. Hibernate学习---第六节:数组&list&map&set的映射配置

    1.实体类,代码如下: package learn.hibernate.bean; import java.util.Date; import java.util.HashMap; import ja ...

  8. Git_错误_03_ Git提交时显示用户 unknown

    这是因为没有设置用户名 $ git config --global user.name "your_name" $ git config --global user.email & ...

  9. Convolutional Neural Networks for Visual Recognition 1

    Introduction 这是斯坦福计算机视觉大牛李菲菲最新开设的一门关于deep learning在计算机视觉领域的相关应用的课程.这个课程重点介绍了deep learning里的一种比较流行的模型 ...

  10. 2017-2018-1 20179215《Linux内核原理与分析》第九周作业

    实验:理解进程调度时机跟踪分析进程调度与进程切换的过程 一.实验要求  (1)理解Linux系统中进程调度的时机,可以在内核代码中搜索schedule()函数,看都是哪里调用了schedule(),判 ...