博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
POJ3252Round Numbers(数位dp)
阅读量:6473 次
发布时间:2019-06-23

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

题意

给出区间$[A, B]$,求出区间内的数转成二进制后$0$比$1$多的数的个数

$1 \leqslant A, B \leqslant 2,000,000,000$

Sol

比较zz的数位dp

直接在二进制下dp就好

$f[i][ze][on]$表示第$i$位,填了$ze$个$0$,$on$个1的方案数

#include
#include
#include
// #include
using namespace std;#define LL long longconst LL MAXN = 101;LL A, B;LL num[MAXN], tot, f[MAXN][MAXN][MAXN];LL dfs(LL x, bool lim, LL ze, LL on) { if(x == 0) return (ze != -1) && (on != -1) && (ze >= on); if(!lim && f[x][ze][on]) return f[x][ze][on]; LL ans = 0; for(LL i = 0; i <= (lim ? num[x] : 1); i++) { if(i == 0) ans += dfs(x - 1, lim && (i == num[x]), ze == -1 ? 1 : ze + 1, on); else { if(on == -1) ans += dfs(x - 1, lim && (i == num[x]), 0, 1); else ans += dfs(x - 1, lim && (i == num[x]), ze, on + 1); } } if(!lim) f[x][ze][on] = ans; return ans;}LL solve(LL x) { tot = 0; while(x) num[++tot] = x % 2, x >>= 1; return dfs(tot, 1, -1, -1);}int main() { cin >> A >> B; cout << solve(B) - solve(A - 1); return 0;}/*1234 44442*/

 

转载地址:http://npvko.baihongyu.com/

你可能感兴趣的文章
JavaNIO基础02-缓存区基础
查看>>
日本开设无人机专业,打造无人机“人才市场”
查看>>
190行代码实现mvvm模式
查看>>
兼容几乎所有浏览器的透明背景效果
查看>>
jeesite 框架搭建与配置
查看>>
Adb移植(一)简单分析
查看>>
Linux VNC server的安装及简单配置使用
查看>>
阿里宣布开源Weex ,亿级应用匠心打造跨平台移动开发工具
查看>>
Android项目——实现时间线程源码
查看>>
招商银行信用卡重要通知:消费提醒服务调整,300元以下消费不再逐笔发送短信...
查看>>
python全栈_002_Python3基础语法
查看>>
C#_delegate - 调用列表
查看>>
[转]Windows的批处理脚本
查看>>
多维数组元素的地址
查看>>
数据库运维体系_SZMSD
查看>>
福大软工1816 · 第三次作业 - 结对项目1
查看>>
selenium多个窗口切换
查看>>
静态库 调试版本 和发布版本
查看>>
JAVA中的finalize()方法
查看>>
慕课网学习手记--炫丽的倒计时效果Canvas绘图与动画基础
查看>>