CF1119H-Triple【FWT】
正题
题目链接:https://www.luogu.com.cn/problem/CF1119H
题目大意
\(n\)个可重集,第\(i\)个里有\(x\)个\(a_i\),\(y\)个\(b_i\),\(z\)个\(c_i\)。
对于每个\(t\in[0,2^k)\)求每个集合里取出一个数使它们异或起来等于\(t\)的方案数。
解题思路
如果直接\(n\)个东西\(FWT\)起来肯定过不了,我们需要根据每个集合里只有三种数这个性质来优化。
因为是\(xor\)卷积,所以第\(i\)个位置\(FWT\)之后对\(j\)造成的影响是\((-1)^{cnt(i\&j)}\)(其中\(cnt(x)\)表示\(x\)在二进制下\(1\)的个数)
那么就有
\]
现在我们就可以单独考虑每个\(x,y,z\)的贡献了,然后每个\(FWT(S_i)[j]\)有\(8\)个状态,为了方便我们缩减一下状态先。
首先我们先让所有的\(x\)都取到,也就是让所有的\(b_i=b_i\ xor\ a_i,c_i=c_i\ xor\ a_i\),然后询问答案的时候我们再异或上一个\(a\)的异或和即可。
现在每个\(FWT(S_i)[j]\)有\(4\)种状态,分别是\((x+y+z),(x+y-z),(x-y+z),(x-y-z)\)。定义这些状态数量分别为\(a_1,a_2,a_3,a_4\)
我们先考虑集合\(i\)的每种状态中\(y\)的影响\(F_i\),有\(F_i[k]=cnt(k\& a_i)\),而所有集合的影响和就是\(\sum_{i=1}^nF_i\)。设\(G_i=IFWT(F_i)\)那么显然有\(G_i[b_i]=1\)其他都为\(0\)。
然后影响和就是
\]
所以直接把\(G\)都加起来然后\(FWT\)就好了,定义\(y\)的影响为\(c_1\)。
然后再同理搞出\(z\)和\(y+z\)的影响,分别为\(c_2,c_3\),那么就有方程组
a_1+a_2+a_3+a_4=n\\
a_1+a_2-a_3-a_4=c_1\\
a_1-a_2+a_3-a_4=c_2\\
a_1-a_2-a_3+a_4=c_3
\end{matrix}\right.\]
解出来就好了,然后用快速幂算出来\(F=\prod_{i=1}^nFWT(S_i)\),求一遍\(IFWT(F)\)即可。
时间复杂度\(O(\ 2^kk+n\log(x+y+z)\ )\)
\(code\)
#include<cstdio>
#include<cstring>
#include<algorithm>
#define ll long long
using namespace std;
const ll N=2e5+10,P=998244353;
const ll inv2=(P+1)/2;
ll n,k,x,y,z,xs;
ll f1[N],f2[N],f3[N],f[N];
ll power(ll x,ll b){
ll ans=1;x%=P;
while(b){
if(b&1)ans=ans*x%P;
x=x*x%P;b>>=1;
}
return ans;
}
void FWT(ll *f,ll n,ll op){
for(ll p=2;p<=n;p<<=1)
for(ll k=0,len=p>>1;k<n;k+=p)
for(ll i=k;i<k+len;i++){
ll x=f[i],y=f[i+len];
if(op==1){
f[i]=x+y;
f[i+len]=x-y;
}
else{
f[i]=(x+y)*inv2%P;
f[i+len]=(x-y)*inv2%P;
}
}
return;
}
signed main()
{
scanf("%lld%lld",&n,&k);k=1<<k;
scanf("%lld%lld%lld",&x,&y,&z);
for(ll i=1;i<=n;i++){
ll a,b,c;
scanf("%lld%lld%lld",&a,&b,&c);
xs^=a;b^=a;c^=a;
f1[b]++;f2[c]++;f3[b^c]++;
}
FWT(f1,k,1);FWT(f2,k,1);FWT(f3,k,1);
for(ll i=0;i<k;i++){
ll c1=f1[i],c2=f2[i],c3=f3[i];
ll a1,a2,a3,a4;
a4=(c3-c1-c2+n)/4;
a3=-(c1-n+2ll*a4)/2;
a2=-(c2-n+2ll*a4)/2;
a1=n-a2-a3-a4;
f[i]=power(x+y+z,a1)%P*power(x+y-z,a2)%P;
f[i]=f[i]*power(x-y+z,a3)%P*power(x-y-z,a4)%P;
}
FWT(f,k,-1);
for(ll i=0;i<k;i++)
printf("%lld ",(f[i^xs]+P)%P);
return 0;
}
CF1119H-Triple【FWT】的更多相关文章
- LOJ2269 [SDOI2017] 切树游戏 【FWT】【动态DP】【树链剖分】【线段树】
题目分析: 好题.本来是一道好的非套路题,但是不凑巧的是当年有一位国家集训队员正好介绍了这个算法. 首先考虑静态的情况.这个的DP方程非常容易写出来. 接着可以注意到对于异或结果的计数可以看成一个FW ...
- hdu6057 Kanade's convolution 【FWT】
题目链接 hdu6057 题意 给出序列\(A[0...2^{m} - 1]\)和\(B[0...2^{m} - 1]\),求所有 \[C[k] = \sum\limits_{i \; and \; ...
- CSU1911 Card Game 【FWT】
题目链接 CSU1911 题解 FWT模板题 #include<algorithm> #include<iostream> #include<cstdlib> #i ...
- BZOJ4589 Hard Nim 【FWT】
题目链接 BZOJ4589 题解 FWT 模板题 #include<algorithm> #include<iostream> #include<cstdlib> ...
- [JZOJ6088] [BZOJ5376] [loj #2463]【2018集训队互测Day 1】完美的旅行【线性递推】【多项式】【FWT】
Description Solution 我们考虑将问题一步步拆解 第一步求出\(F_{S,i}\)表示一次旅行按位与的值为S,走了i步的方案数. 第二步答案是\(F_{S,i}\)的二维重复卷积,记 ...
- 【杂题】[AGC034F] RNG and XOR【集合幂级数】【FWT】【DP】
Description 你有一个随机数生成器,它会以一定的概率生成[0,2^N-1]中的数,每一个数的概率是由序列A给定的,Pi=Ai/sum(Ai) 现在有一个初始为0的数X,每一轮随机生成一个数v ...
- CF662C Binary Table【FWT】
CF662C Binary Table 题意: 给出一个\(n\times m\)的\(01\)矩阵,每次可以反转一行或者一列,问经过若干次反转之后,最少有多少个\(1\) \(n\le 20, m\ ...
- bzoj4589-Hard Nim【FWT】
正题 题目链接:https://darkbzoj.tk/problem/4589 题目大意 求有多少个长度为\(n\)的数列满足它们都是不大于\(m\)的质数且异或和为\(0\). 解题思路 两个初始 ...
- hdu5909-Tree Cutting【FWT】
正题 题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=5909 题目大意 给出\(n\)和\(m\)(\(m=2^k\)).再给出一个大小为\(n\)的树 ...
随机推荐
- 【Tools】SSHUsage
SSH(Secure Shell 的缩写)是一种网络协议,用于加密两台计算机之间的通信,并且支持各种身份验证机制.还能对操作者进行认证(authentication)和授权(authorization ...
- GC垃圾收集器
垃圾收集器是垃圾收集算法的具体实现,是执行垃圾收集算法的,是守护线程. HotSport虚拟机采用分代收集(JVM规范并未对堆区进行划分),将堆分为年轻代和老年代,垃圾收集器也是这样组合使用的,不过已 ...
- 栈编程和函数控制流: 从 continuation 与 CPS 讲到 call/cc 与协程
原标题:尾递归优化 快速排序优化 CPS 变换 call/cc setjmp/longjmp coroutine 协程 栈编程和控制流 讲解 本文为部分函数式编程的扩展及最近接触编程语言控制流的学习和 ...
- Asp.NetCore 中Aop的应用
前言 其实好多项目中,做一些数据拦截.数据缓存都有Aop的概念,只是实现方式不一样:之前大家可能都会利用过滤器来实现Aop的功能,如果是Asp.NetCore的话,也可能会使用中间件: 而这种实现方式 ...
- 100个裁判对n个选手做无并列排名问题探析
原题:n 个选手(n ≥ 3)参加花样自行车比赛,100 个裁判独立对各选手的表现给出无并列排名.已知对任意三个选手 A.B.C 和任意三个裁判 X.Y.Z 均不会出现如下的情形:X 给出 A > ...
- [考试总结]noip模拟39
不写那么多没用的了 开题就发现 \(T4\) 原题, \(T1\) 大水题. 然后发现 \(T4\) 忘了.... 不扯了 打地鼠 大水题,我代码都不想放... 算了,还是放一下吧.. #includ ...
- Intel® QAT加速卡之加密、哈希操作流程和示例
Intel QAT 加密API介绍 文章主要讲述了Intel QAT 加密API接口的说明,以及多种应用场景下的使用方法. 文章目录 Intel QAT 加密API介绍 1. 概述 1.1 会话(se ...
- AntDesign VUE:Model组件的Button的事件this指向undefined的问题(箭头函数)
问题 一个很简单的this指向问题引起的报错: 记录下来主要是想看看这玩意到底指向哪里: 真不戳 解决方法 ES6的箭头函数,有人理解它就是没有this指向,我个人理解是它的this指向函数体的上一级 ...
- Spring基于XML方式加载Bean定义信息(又名:Spring IOC源码时序图)-图解
- 完美数java
完全数(Perfect number),又称完美数或完备数,是一些特殊的自然数.它所有的真因子(即除了自身以外的约数)的和(即因子函数),恰好等于它本身.如果一个数恰好等于它的因子之和,则称该数为&q ...