D. Jzzhu and Numbers
这就是这个题目的意思,真的感觉这个思想是太神奇了,我这种菜逼现在绝壁想不到这样的证明的过程的,还有就是这个题的推道过程,以下思路纯属借鉴卿学姐的,还是自己太菜了,,,,
讲道理这种问题我真的想不到用容斥原理来做啊,那现在我就用容斥原理来讲一下这个问题,,,
|!A1∩!A2∩!A3∩....!An|=sum-奇数的组合+偶数的组合。。。。
!A1代表的就第一个位置为0的方案,同理其他的以此类推。。。
我们知道要是一个数x&i=i; 那么x和i有可能的关系就是x>=i 就是i有一的位置x的位置是肯定有1的。。
经过我今天早上的疯狂的找原题,今天终于在codeforce找到了原题,要是一共有20位的话,总共的所有的情况就是2^20-1 ,这个子的话我们只要算出来
aj&i=i有多少种数据就行了,这样子的话我们再统计i中的1的个数,这样子的话我们就能用dp来做这个问题了,我们用dp[i][k]代表前i位有可能和k不同的&k=k的数量,所以当第i为为0的时候那么 dp[i][k]+=dp[i-1][k]+dp[i-1][k+2^i];
那么当第i位为1的时候,dp[i][k]+=dp[i-1][k],那么就是代表第i为必定相同,然后再根据容斥原理的定义这个题到此已经完成。。。
泣不成声啊! 妈的竟然过了。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 | #include<bits/stdc++.h> #define ll long long using namespace std; const ll mod=1000000007; const int N=1e6+5; ll dp[22][1000003]; ll g[N]; int a[N]; int s[N]; void inist( int n) { g[0]=1; for ( int i=1;i<=n;i++) { g[i]=2*g[i-1]; g[i]%=mod; dp[0][a[i]]++; } } void work( int k, int n) { // 一共k-1位 for ( int i=1;i<k;i++) { for ( int j=1;j<=1000000;j++) { if (j&(1<<(i-1))) { dp[i][j]=dp[i-1][j]; s[j]^=1; } else { dp[i][j]=dp[i-1][j]; if ((j|(1<<(i-1)))>1e6) continue ; dp[i][j]+=dp[i-1][j|(1<<(i-1))]; } } } int num=k-1; ll ans=(g[n]-1+mod)%mod; for ( int i=1;i<=1000001;i++) { if (s[i]==0) {ans=(ans+g[dp[20][i]]%mod)%mod; ans=(ans-1+mod)%mod;} else {ans=(ans-g[dp[20][i]]%mod)%mod; ans=(ans+1+mod)%mod;} }cout<<ans<<endl; } int main() { int n; cin>>n; for ( int i=1;i<=n;i++) scanf ( "%d" ,&a[i]); inist(n); work(21,n); } |
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】凌霞软件回馈社区,博客园 & 1Panel & Halo 联合会员上线
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】博客园社区专享云产品让利特惠,阿里云新客6.5折上折
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· .NET Core 托管堆内存泄露/CPU异常的常见思路
· PostgreSQL 和 SQL Server 在统计信息维护中的关键差异
· C++代码改造为UTF-8编码问题的总结
· DeepSeek 解答了困扰我五年的技术问题
· 为什么说在企业级应用开发中,后端往往是效率杀手?
· 清华大学推出第四讲使用 DeepSeek + DeepResearch 让科研像聊天一样简单!
· 推荐几款开源且免费的 .NET MAUI 组件库
· 实操Deepseek接入个人知识库
· 易语言 —— 开山篇
· Trae初体验