【2017 Multi-University Training Contest - Team 7】Just do it
【Link】:http://acm.hdu.edu.cn/showproblem.php?pid=6129
【Description】
设定b【i】=a【1】^a【2】^a【3】^………………a【i】;
每进行一次,我们可以从a数组得到一个b数组。问进行m次的结果。
【Solution】
我们把前几轮的结果都写出来;
会发现,最后每一个位置ai的结果都是
t1@a1+t2@a2+…+ti@ai的形式.
这里的x@y表示x个y做异或运算.
t1是系数,它>=0
且最后的ai的系数,是a[i+1]的后i项系数.
也就是说只要我们把an的t1到tn求出来就好了;
会发现有a[i][j] = a[i][j-1]+a[i-1][j]的规律..
这样就能打一张大表了
然后就是找规律了。。
在OEIS上发现。。
第i列就是C(i+m-2,i-1);
则t1..tn都能求出来了
我们不用知道这一项具体是什么;
只希望知道它的奇偶性就好。
(奇数就为1,否则为0);
有个结论.
当(n&m) == m的时候,C(n,m)的值才为奇数
这样就能根据t1..tn算出an了;
再根据最后的ai的系数,是a[i+1]的后i项系数进而可以算出a1..an-1
这里我只记录了ti为1的位置,且在做的时候把没用的位置删掉了.
这样避免了O(n^2)的复杂度.
因为当(n&m) == m的时候,C(n,m)的值才为奇数,可以想见最后系数为1的值是挺少的
【NumberOf WA】
1
(PE了一发,注意行末空格啊!!)
【Reviw】
OEIS帮了大忙.
【Code】
#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 ms(x,y) memset(x,y,sizeof x)
#define ri(x) scanf("%d",&x)
#define rl(x) scanf("%lld",&x)
#define rs(x) scanf("%s",x+1)
#define oi(x) printf("%d",x)
#define ol(x) printf("%lld",x)
#define oc putchar(' ')
#define os(x) printf(x)
#define all(x) x.begin(),x.end()
#define open() freopen("f:\\rush.txt","r",stdin)
#define close() ios::sync_with_stdio(0)
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 = 2e5;
int a[N+100],t,n,m,b[N+100];
vector <int> v;
int c(int n,int m){
if ( (n&m) == m)
return 1;
else
return 0;
}
int main(){
//open();
//close();
ri(t);
while (t--){
ri(n),ri(m);
rep1(i,1,n) ri(a[i]);
v.clear();
for (int i = 1,j = n;i <= n;i++,j--){
int b;
if (i == 1)
b = 1;
else
if (i == 2) b = m&1;
else
if (i == 3) b = c(m+1,2);
else
if (i == 4) b = c(m+2,3);
else
b = c(m+i-2,i-1);
if (b==1) v.pb(j);
}
rep2(i,n,1){
while ( (int) v.size()){
int k = v.back();
if (k-(n-i)<=0) {
v.pop_back();
continue;
}
break;
}
int len = v.size();
int temp = 0;
rep1(k,0,len-1){
int key = v[k];
int j = key -(n-i);
temp^=a[j];
}
b[i] = temp;
}
rep1(i,1,n) {
oi(b[i]);
if (i == n)
puts("");
else
oc;
}
}
return 0;
}
【2017 Multi-University Training Contest - Team 7】Just do it的更多相关文章
- 【2017 Multi-University Training Contest - Team 2】TrickGCD
[Link]:http://acm.hdu.edu.cn/showproblem.php?pid=6053 [Description] 给你一个b数组,让你求一个a数组: 要求,该数组的每一位都小于等 ...
- 【2017 Multi-University Training Contest - Team 2】Maximum Sequence
[Link]:http://acm.hdu.edu.cn/showproblem.php?pid=6047 [Description] 给你一个数列a和一个数列b; 只告诉你a的前n项各是什么; 然后 ...
- 【2017 Multi-University Training Contest - Team 2】 Regular polygon
[Link]: [Description] 给你n个点整数点; 问你这n个点,能够组成多少个正多边形 [Solution] 整点只能构成正四边形. 则先把所有的边预处理出来; 枚举每某两条边为对角线的 ...
- 【2017 Multi-University Training Contest - Team 2】 Is Derek lying?
[Link]: [Description] 两个人都做了完全一样的n道选择题,每道题都只有'A','B','C' 三个选项,,每道题答对的话得1分,答错不得分也不扣分,告诉你两个人全部n道题各自选的是 ...
- 【2017 Multi-University Training Contest - Team 5】Rikka with Competition
[Link]: [Description] [Solution] 把所有人的能力从大到小排; 能力最大的肯定可能拿冠军; 然后一个一个地往后扫描; 一旦出现a[i-1]-a[i]>k; 则说明从 ...
- 【2017 Multi-University Training Contest - Team 5】Rikka with Subset
[Link]: [Description] 给你a数组的n个数的所有2^n个子集的2^n个子集元素的和; 子集元素的和最大为m; 告诉你各个子集元素的和出现的次数; 如 1 2 则0出现1次,1出现1 ...
- 【2017 Multi-University Training Contest - Team 5】Rikka with Graph
[Link]:http://acm.hdu.edu.cn/showproblem.php?pid=6090 [Description] 给你n个点; 让你在这n个点上最多连m条无向边; 使得 ∑ni= ...
- 【2017 Multi-University Training Contest - Team 4】Time To Get Up
[Link]: [Description] [Solution] 把每个数字长什么样存到数组里就好;傻逼题. (直接输入每一行是什么样子更快,不要一个字符一个字符地输入) [NumberOf WA] ...
- 【2017 Multi-University Training Contest - Team 4】Counting Divisors
[Link]:http://acm.hdu.edu.cn/showproblem.php?pid=6069 [Description] 定义d(i)为数字i的因子个数; 求∑rld(ik) 其中l,r ...
- 【2017 Multi-University Training Contest - Team 3】RXD and math
[Link]: [Description] [Solution] 发现1010mod(109+7)=999999937; 猜测答案是nk 写个快速幂; 注意对底数先取模; [NumberOf WA] ...
随机推荐
- 逆波兰表达式解数学运算(c#)
逆波兰表达式解数学运算 感谢作者 http://blog.csdn.net/liuyuxusuixiang/article/details/25289715 public class TCalcula ...
- js插件---强大的图片裁剪Cropper
js插件---强大的图片裁剪Cropper 一.总结 一句话总结:官网或者github里面的文档或者demo才是真的详细 使用的话找到图片裁剪后的base64数据,然后这个数据可下载可传递到服务器 1 ...
- 字典(dictionary)与映射(map)
1. 字典:key-value 键值对 反转字典:reverse_dict = dict(zip(D.values(), D.keys())) 前提要保证 D 的 value 不会出现重复,因为字典反 ...
- BZOJ3569: DZY Loves Chinese II(线性基构造)
Description 神校XJ之学霸兮,Dzy皇考曰JC. 摄提贞于孟陬兮,惟庚寅Dzy以降. 纷Dzy既有此内美兮,又重之以修能. 遂降临于OI界,欲以神力而凌♂辱众生. 今Dzy有一魞歄图, ...
- 【Django】安装及配置
目录 MVC框架与MTV框架 Django的MTV模式 Django框架图示 安装及配置 创建一个Django项目 目录介绍 运行Django项目 启动Django报错 模版文件配置 静态文件配置 A ...
- strings---对象文件或二进制文件中查找可打印的字符串
strings命令在对象文件或二进制文件中查找可打印的字符串.字符串是4个或更多可打印字符的任意序列,以换行符或空字符结束. strings命令对识别随机对象文件很有用. 语法 strings [ - ...
- mysql 查看单个表每个索引的大小
/*单个表每个索引的大小*/ SELECT sum(stat_value) pages, table_name part, index_name, concat(,),'M',' rows') * @ ...
- 详解:Linux Chrony 设置服务器集群同步时间
导读: Chrony是一个开源的自由软件,像CentOS 7或基于RHEL 7操作系统,已经是默认服务,默认配置文件在 /etc/chrony.conf 它能保持系统时间与时间服务器(NTP)同步,让 ...
- Linux 内核链表使用举例
链表数据结构的定义非常简洁: struct list_head { struct list_head *next, *prev; }; list_head结构包括两个指向list_head结构的指针p ...
- 关于cocos2dx之lua使用TableView
在手机游戏的开发中,滚动是一项很重要的操作,而cocos2dx中使用的最广泛的就属于TableView了,只是由于cocos2dx的接口比較晦涩,所以须要一个熟悉的过程.本文主要解说怎样使用Table ...