[51Nod 1301] 集合异或和 (dp)
2024-09-03 09:01:42
Solution
一道比较好的dp题 想了半天组合数QAQ
首先要知道的是 A<B一定是B有一位是1且A的这位是0且前面都相等
那么肯定是要枚举这一位在哪里然后求出方案数
方案数考虑类似背包的方法分三种情况转移具体见代码
Code
#include <cstdio>
#include <cstring>
#include <cstdlib>
#include <iostream>
#include <algorithm>
#define F(i,a,b) for(register int i=(a);i<=(b);i++)
using namespace std;
typedef long long LL;
const int N=5000,MOD=1e9+7;
int n,m;
LL ans,f[2][N][2];
int main() {
cin>>n>>m;
for(int i=0;(1<<i)<=max(n,m);i++) {
memset(f,0,sizeof(f));
f[0][0][0]=1;
for(int j=1;j<=max(n,m);j++) {
int x=(j>>i)&1,c=j&1;
for(int k=0;k<=2048;k++) F(X,0,1) {
f[c][k][X]=f[c^1][k][X];
if(j<=n) f[c][k][X]=(f[c][k][X]+f[c^1][k^j][X])%MOD;
if(j<=m) f[c][k][X]=(f[c][k][X]+f[c^1][k^j][X^x])%MOD;
}
}
F(j,(1<<i),(1<<(i+1))-1) ans=(ans+f[(max(n,m)&1)][j][1])%MOD;
}
printf("%lld",ans%MOD);
return 0;
}
最新文章
- Android Studio 2.2.2导入Eclipse中创建的项目
- Runtime 动态加载方法
- 调整vbox虚拟机下的linux全屏模式及分辨率
- svn文件批量清除
- ABAP报表中负值展示问题的处理方法
- Log4net配置文件一般配置
- Redis系列-存储篇string主要操作函数小结
- 炼数成金hadoop视频干货06-10
- php开发环境以及插件的配置安装
- 最接近原生APP体验的高性能前端框架-MUI
- Linux Hung Task分析
- Developing Vert.x Modules with Gradle
- Arthas:线上问题排查工具
- ThreadPoolExecutor源码解读
- ios 获取视频截图
- TI开发环境下载资源
- LOJ2522:[FJOI2018]邮递员问题(乱搞)
- WebXml.com.cn 中国股票行情数据 WEB 服务(支持深圳和上海股市的全部基金、债券和股票),数据即时更新
- Qt Creator build遇到error lnk1158 无法运行rc.exe
- 深入浅出 Java Concurrency (12): 锁机制 part 7 信号量(Semaphore)
热门文章
- 最新版本号cocos2d&;#173;2.0&;#173;x&;#173;2.0.2使用新资源载入策略!不再沿用-hd、-
- Pycharm之Terminal使用
- Spring发送邮件_javax.mail.AuthenticationFailedException异常已解决
- 表现与数据分离;前台MVC
- 20170322Linux
- 【字符串处理】关于KMP算法输出的是什么&;代码
- 在MTK平台里,,函数kal_prompt_trace起什么作用???Kal_prompt_trace的参数有表示什么?
- ssdb底层实现——ssdb底层是leveldb,leveldb根本上是skiplist(例如为存储多个list items,必然有多个item key,而非暴力string cat),用它来做redis的list和set等,势必在数据结构和算法层面上有诸多不适
- 正确的缩写document。querySelector
- Coursera公开课-Machine_learing:编程作业6