传送门

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;
}

最新文章

  1. Android Studio 2.2.2导入Eclipse中创建的项目
  2. Runtime 动态加载方法
  3. 调整vbox虚拟机下的linux全屏模式及分辨率
  4. svn文件批量清除
  5. ABAP报表中负值展示问题的处理方法
  6. Log4net配置文件一般配置
  7. Redis系列-存储篇string主要操作函数小结
  8. 炼数成金hadoop视频干货06-10
  9. php开发环境以及插件的配置安装
  10. 最接近原生APP体验的高性能前端框架-MUI
  11. Linux Hung Task分析
  12. Developing Vert.x Modules with Gradle
  13. Arthas:线上问题排查工具
  14. ThreadPoolExecutor源码解读
  15. ios 获取视频截图
  16. TI开发环境下载资源
  17. LOJ2522:[FJOI2018]邮递员问题(乱搞)
  18. WebXml.com.cn 中国股票行情数据 WEB 服务(支持深圳和上海股市的全部基金、债券和股票),数据即时更新
  19. Qt Creator build遇到error lnk1158 无法运行rc.exe
  20. 深入浅出 Java Concurrency (12): 锁机制 part 7 信号量(Semaphore)

热门文章

  1. 最新版本号cocos2d&amp;#173;2.0&amp;#173;x&amp;#173;2.0.2使用新资源载入策略!不再沿用-hd、-
  2. Pycharm之Terminal使用
  3. Spring发送邮件_javax.mail.AuthenticationFailedException异常已解决
  4. 表现与数据分离;前台MVC
  5. 20170322Linux
  6. 【字符串处理】关于KMP算法输出的是什么&amp;代码
  7. 在MTK平台里,,函数kal_prompt_trace起什么作用???Kal_prompt_trace的参数有表示什么?
  8. ssdb底层实现——ssdb底层是leveldb,leveldb根本上是skiplist(例如为存储多个list items,必然有多个item key,而非暴力string cat),用它来做redis的list和set等,势必在数据结构和算法层面上有诸多不适
  9. 正确的缩写document。querySelector
  10. Coursera公开课-Machine_learing:编程作业6