当前位置: 首页 > news >正文

题解:CF1829H Don‘t Blame Me

一:思路:

    在本题,我们可以先设dpi,j为选到第 i 个数时,按位与结果为 j 的方案数

接下来分两种情况分类讨论:
 - 如果不选:加上选到第 i−1 个数的方案数,也就是dpi,j = dpi,j + dpi-1,j
- 如果选:与上第 i 个数,也就是:dp i,j & a i = dp i,j & ai + dp i-1,j


1) 由于题目给出的 k 表示二进制位有 k 个 1,那我们就要在 0-63 中找到所有二进制位中有 k 个 1 的数,并将方案数累加。
2) 这里的方法找是二进制中有多少个 1,不停的与比当前数少 1 的数进行按位与,这样当目前的数变成 0 时,二进制位 1 的个数也就统计出来了。

        代码:

#include<bits/stdc++.h>
#define ll long long
using namespace std;
const int N=2e5+10,mod=1e9+7;
ll t,n,m,a[N];
ll dp[N][80];
ll ldnsbshljbl(ll x){ll cnt=0;while(x!=0){cnt++;x&=x-1;}return cnt;}int main(){scanf("%lld",&t);while(t--){scanf("%lld%lld",&n,&m);for(int i=1;i<=n;i++){scanf("%lld",&a[i]);for(int j=0;j<64;j++){dp[i][j]=0;}dp[i][a[i]]=1;}for(int i=1;i<=n;i++){for(int j=0;j<64;j++){dp[i][j]=(dp[i][j]+dp[i-1][j])%mod;dp[i][j&a[i]]=(dp[i][j&a[i]]+dp[i-1][j])%mod;}}ll ans=0;for(int i=0;i<64;i++){if(ldnsbshljbl(i)==m){ans=(ans+dp[n][i])%mod;}}printf("%lld\n",ans);}return 0;
}
http://www.dtcms.com/a/283852.html

相关文章:

  • 相位中心偏置天线的SAR动目标检测
  • 代码随想录算法训练营第二十三天
  • Apache SeaTunnel配置使用案例
  • 【Leetcode】栈和队列算法题(逆波兰表达式、二叉树层序遍历、最小栈、栈的压入弹出序列)
  • 贪心算法(排序)
  • 如何通过ATS/HTTPS数据防篡改来加密视频?
  • 部署-k8s和docker的区别和联系
  • 川翔云电脑:云端算力新标杆,创作自由无边界
  • STM32上移植Lua解析器
  • 性能优化实践:Modbus 在高并发场景下的吞吐量提升(二)
  • ClickHouse 多表 JOIN 时 SELECT * 语法错误解析与解决方案
  • Web3智能合约技术论述
  • GraphQL的N+1问题如何被DataLoader巧妙化解?
  • 阿里京东美团即时零售大战,品牌商如何从被动到主动?
  • 多端协同的招聘系统源码开发指南:小程序+APP一体化设计
  • C++性能优化与现代工程实践:打造高效可靠的软件系统
  • Unity_通过鼠标点击屏幕移动屏幕里的一个对象
  • Redis4缓存穿透:布隆过滤器与空对象方案
  • Python爬虫实战:Requests与Selenium详解
  • 电脑截图软件排行榜 Windows和mac电脑截图软件TOP10
  • Perspective:一款开源的交互式分析和数据可视化组件
  • ZKmall开源商城架构助力增长:多端流量聚合与用户体验
  • macOS 12.7.6部署Ollama+Dify避坑指南
  • 集群聊天服务器各个类进行详解
  • LAMP迁移LNMP Nginx多站点配置全流程
  • 大型语言模型(LLM)在网络安全中最具商业价值的应用场景(Grok3 回答 DeepSearch模式)
  • Java-75 深入浅出 RPC Dubbo Java SPI机制详解:从JDK到Dubbo的插件式扩展
  • 新版本flutter(3.32.7) android 端集成百度地图sdk
  • 网络编程7.17
  • cors跨域资源共享