【cf contest 1119 H】Triple
题目
给出 \(n\) 个三元组\(\{ a_i,b_i,c_i \}\)和\(x,y,z\);
将每个三元组扩展成(\(x\)个\(a_i\),\(y\)个\(b_i\),\(z\)个\(c_i\));
问从\(n\)组里面每组选一个数,这\(n\)个数异或值为x 的方案数\(mod \ 998244353\)是多少;
\(1 \le n \le 10^5 \ , \ 1 \le k \le 17 \ , \ 0 \le x,y,z \le 10^9 \ , 0 \le \ a_i,b_i,c_i \lt 2^k\) ;
题解
最后的答案异或一个 \(\oplus_{i=1}^{n} a_i\) ,令\(\{a_i,b_i,c_i\}\)变成$ { 0 , a_i \wedge b_i , a_i \wedge c_i } $ ;
令\(F_{i,0}+=x \ , \ F_{i,b_i}+=y \ , \ F_{i,c_i}+=z\) ,把所有\(fwt(F_i)\)点乘起来再\(ifwt\)回去即可;
考虑如何求最后的乘积\(\Pi F_i\);
对于\(fwt(F_i)\),每一项一定都是\(x+y+z \ , \ x+y-z \ , \ x-y+z \ , x - y - z\) 之一;
设纵向的个数为\(i,j,k,l\),解出每一位\(i,j,k,l\)即可快速算出最后的乘积,首先:
\[\begin{align}
i +j +k + l = n
\end{align}
\]令只考虑\(F_i,b_i=1\),设所有\(F\)加起来\(fwt\)到得到对应位值上的值为\(p\)(x=0,y=1,z=0):
\[i + j - k - l = p
\]同理只令\(F_i,c_i = 1\),有(x=0,y=0,z=1):
\[i - j + k - l = p
\]令\(F_{i,b_i \wedge c_i}=1\),相当于上面两个的点值乘法,有
\[i - j - k + l = p
\]解方程即可;
最后\(ifwt\)回来;
#include<bits/stdc++.h>
#define mod 998244353
#define ll long long
using namespace std;
const int N=1<<17;
int n,X,Y,Z,l,s;
int A[N],B[N],C[N],ans[N];
char gc(){
static char*p1,*p2,S[1000000];
if(p1==p2)p2=(p1=S)+fread(S,1,1000000,stdin);
return(p1==p2)?EOF:*p1++;
}
int rd(){
int x=0;char c=gc();
while(c<'0'||c>'9')c=gc();
while(c>='0'&&c<='9')x=(x<<1)+(x<<3)+c-'0',c=gc();
return x;
}
int pw(int x,int y){
int re=1;
while(y){
if(y&1)re=(ll)re*x%mod;
y>>=1;x=(ll)x*x%mod;
}
return re;
}
void fwt(int*a){
for(int i=1;i<l;i<<=1)
for(int j=0;j<l;j+=i<<1)
for(int k=0;k<i;++k){
int t1=a[j+k],t2=a[j+k+i];
a[j+k]=t1+t2;
a[j+k+i]=t1-t2;
}
}
void dec(int&x,int y){x-=y;if(x<0)x+=mod;}
void ifwt(int*a){
for(int i=1;i<l;i<<=1)
for(int j=0;j<l;j+=i<<1)
for(int k=0;k<i;++k){
int iv2=(mod+1)/2;
int t1=a[j+k],t2=a[j+k+i];
a[j+k]=(ll)(t1+t2)*iv2%mod;
a[j+k+i]=(ll)(t1-t2+mod)*iv2%mod;
}
}
int main(){
//freopen("H.in","r",stdin);
//freopen("H.out","w",stdout);
n=rd();l=1<<rd();
X=rd();Y=rd();Z=rd();
for(int i=1;i<=n;++i){
int a=rd(),b=rd(),c=rd();
s^=a;b^=a;c^=a;a=b^c;
A[b]++,B[c]++,C[a]++;
}
fwt(A);fwt(B);fwt(C);
int t1=((ll)X+Y+Z)%mod;
int t2=((ll)X+Y-Z+mod)%mod;
int t3=((ll)X-Y+Z+mod)%mod;
int t4=((ll)X-Y-Z+mod+mod)%mod;
for(int i=0;i<l;++i){
ans[i] =
(ll)pw(t1,(n+A[i]+B[i]+C[i])>>2)
*pw(t2,(n+A[i]-B[i]-C[i])>>2)%mod
*pw(t3,(n-A[i]+B[i]-C[i])>>2)%mod
*pw(t4,(n-A[i]-B[i]+C[i])>>2)%mod;
}
ifwt(ans);
for(int i=0;i<l;++i)printf("%d ",ans[i^s]);
return 0;
}
【cf contest 1119 H】Triple的更多相关文章
- 【cf contest 1119 G】Get Ready for the Battle
题目 你有\(n\)个士兵,需要将他们分成\(m\)组,每组可以为0: 现在这些士兵要去攻打\(m\)个敌人,每个敌人的生命值为\(hp_i\) : 一轮游戏中一组士兵选定一个攻打的敌人,敌人生命值- ...
- 【codeforces contest 1119 F】Niyaz and Small Degrees
题目 描述 \(n\) 个点的树,每条边有一个边权: 对于一个 \(X\) ,求删去一些边后使得每个点的度数 \(d_i\) 均不超过 \(X\) 的最小代价: 你需要依次输出 \(X=0 \to n ...
- B. Lost Number【CF交互题 暴力】
B. Lost Number[CF交互题 暴力] This is an interactive problem. Remember to flush your output while communi ...
- 【CF contest/792/problem/E】
E. Colored Balls time limit per test 1 second memory limit per test 256 megabytes input standard inp ...
- 【cf补题记录】Codeforces Round #608 (Div. 2)
比赛传送门 再次改下写博客的格式,以锻炼自己码字能力 A. Suits 题意:有四种材料,第一套西装需要 \(a\).\(d\) 各一件,卖 \(e\) 块:第二套西装需要 \(b\).\(c\).\ ...
- 3.26-3.31【cf补题+其他】
计蒜客)翻硬币 //暴力匹配 #include<cstdio> #include<cstring> #define CLR(a, b) memset((a), (b), s ...
- 【郑轻邀请赛 H】 维克兹的进制转换
[题目链接]:https://acm.zzuli.edu.cn/zzuliacm/problem.php?id=2134 [题意] [题解] 设f[i]表示数字i分解为二进制数的方案数; 则 如果i为 ...
- 【cf 483 div2 -C】Finite or not?(数论)
链接:http://codeforces.com/contest/984/problem/C 题意 三个数p, q, b, 求p/q在b进制下小数点后是否是有限位. 思路 题意转化为是否q|p*b^x ...
- 【CF 189A Cut Ribbon】dp
题目链接:http://codeforces.com/problemset/problem/189/A 题意:一个长度为n的纸带,允许切割若干次,每次切下的长度只能是{a, b, c}之一.问最多能切 ...
随机推荐
- 【leetcode-78 dfs+回溯】 子集
子集 给定一组不含重复元素的整数数组 nums,返回该数组所有可能的子集(幂集). 说明:解集不能包含重复的子集. 示例: 输入: nums = [1,2,3] 输出: [ [3], [1], ...
- 全栈项目|小书架|服务器端-NodeJS+Koa2 实现书籍详情接口
通过上篇文章 全栈项目|小书架|微信小程序-首页水平轮播实现 我们实现了前端(小程序)效果图的展示,这篇文章来介绍服务器端的实现. 书籍详情分析 书籍详情页面如下: 从上图可以分析出详情页面大概有以下 ...
- SSO实现机制
引言 单点登录有许多开发商提供解决方案,本文以yale大学SSO开源项目CAS为例,介绍单点登录实现机制. 术语解释 SSO-Single Sign On,单点登录 TGT-Ticket Granti ...
- python爬虫-房天下-登录
房天下-登录 本次爬取的网址为:https://passport.fang.com 一.分析请求 输入用户名和密码,点击登录按钮 请求的参数为: uid: 123456789 pwd: 64ccd42 ...
- 【MySQL】数据库中间件Atlas
1.介绍 Atlas 是由 Qihoo 360公司Web平台部基础架构团队开发维护的一个基于MySQL协议的数据中间层项目.它在MySQL官方推出的MySQL-Proxy 0.8.2版本的基础上,修改 ...
- javascript ~~ 符号是什么意思呢?
~ bitwise NOT 运算符 ~对操作数按位取反,两个的意思即作两次取反操作,其实是等作原数本身(操作数是32整数范围内) ~~(Math.random()*7) 即 var n = Math. ...
- IDEA插件:search with bing、search with baidu
//转载请注明出处:https://www.cnblogs.com/nreg/p/11267169.html 当项目出现错误时,经常需要复制错误信息粘贴到浏览器查询,但是手动复制再粘贴太麻烦了, 因此 ...
- (摘录笔记)JAVA学习笔记SSH整合搭建项目
1:当然是导jar包啦: struts2: spring: hibernate: 至于这些jar包是什么作用,我想就不必我解释了,大家都懂得,ssh2基本的jar包: 还有一些其他jar包:strut ...
- 如何封装一个自己的win7系统并安装到电脑做成双系统
说明: 目前我是刚试玩所以总结得没有很详细,先粗略放一个,下次有时间再分开整理系统封装或者如何制作双系统. 教程参考地址: 1. https://www.sysceo.com/forum/thread ...
- 19.centos7基础学习与积累-005-命令总结01
从头开始积累centos7系统运用 大牛博客:https://blog.51cto.com/yangrong/p5 1.查看命令帮助的方法: --help 适用于一般命令,非内置命令 man 适用于 ...