博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
一道不知道哪里来的容斥题
阅读量:5094 次
发布时间:2019-06-13

本文共 1111 字,大约阅读时间需要 3 分钟。

题意:

1545866-20190131170156838-413637236.png
容斥二进制意义下至少哪些位置不相等。

#include
#include
#include
#include
#include
#include
#include
#include
#include
#define N 2200000#define L 2000000#define eps 1e-7#define inf 1e9+7#define db double#define ll long long#define ldb long doubleusing namespace std;inline ll read(){ char ch=0; ll x=0,flag=1; while(!isdigit(ch)){ch=getchar();if(ch=='-')flag=-1;} while(isdigit(ch)){x=(x<<3)+(x<<1)+ch-'0';ch=getchar();} return x*flag;}const ll mo=998244353;ll ksm(ll x,ll k){ ll ans=1; while(k) { if(k&1)ans=ans*x%mo; k>>=1; x=x*x%mo; } return ans;}ll a[N],f[N],mi[N];int main(){ ll n=read(),ans; mi[0]=1; for(ll i=1;i<=n;i++)a[i]=read(),mi[i]=(mi[i-1]*2)%mo; for(ll i=1;i<=(1<<20)-1;i++)f[i]=f[i>>1]+(i&1); ans=mi[n]-2;ans=(ans*ksm(2,mo-2))%mo; for(ll s=0;s<=(1<<20)-1;s++) { ll cnt=0; for(ll i=1;i<=n;i++)if(s==(a[i]&s))cnt++; if(cnt==0||cnt==n)continue; if(f[s]&1)ans=(ans-(mi[cnt]-1))%mo; else ans=(ans+(mi[cnt]-1))%mo; } printf("%lld",(ans%mo+mo)%mo); return 0;}

转载于:https://www.cnblogs.com/Creed-qwq/p/10342758.html

你可能感兴趣的文章
设计器 和后台代码的转换 快捷键
查看>>
STL容器之vector
查看>>
数据中心虚拟化技术
查看>>
复习文件操作
查看>>
SQL Server 使用作业设置定时任务之一(转载)
查看>>
第二阶段冲刺-01
查看>>
BZOJ1045 HAOI2008 糖果传递
查看>>
JavaScript 克隆数组
查看>>
eggs
查看>>
python3 生成器与迭代器
查看>>
CPU,寄存器,一缓二缓.... RAM ROM 外部存储器等简介
查看>>
git .gitignore 文件不起作用
查看>>
digitalocean --- How To Install Apache Tomcat 8 on Ubuntu 16.04
查看>>
【题解】[P4178 Tree]
查看>>
cer证书签名验证
查看>>
【深度学习】caffe 中的一些参数介绍
查看>>
QML学习笔记之一
查看>>
App右上角数字
查看>>
小算法
查看>>
201521123024 《java程序设计》 第12周学习总结
查看>>