旁听途说这个名字很久了,了解了一下。

改题目的意思是给你若干区间,让你找寻区间内不含62或4的数。

首先暴力必然T。。。那么实际上就是说,想办法做一种预处理,在每次输入的时候取值运算就可以了。

既然是DP先说一下dp[ i ][ j ]:

表示有 i 位并且最高为是 j 的数包含多少符合条件的数。

(读者仔细思考一下为什么这样设定,为什么这样子可以得到答案,实际dp训练的就是这个)

然后接下来最重要的就是DP转移方程了,首先对于i等于1的情况来说直接赋值就好了。

如果 i 不等于1,则传递关系如下:

dp[ i ][ j ]=  if ( j == 4 ) dp[ i ][ j ]=0

     else if ( j != 6) dp[ i ][ j ]=Σdp[ i -1][ k ] (k=0,1,2,3,4,5,6,7,8,9)

     else if ( j == 6) dp[ i ][ j ]=Σdp[ i -1][ k ] (k=0,1,3,4,5,6,7,8,9)

通俗的言语表达就是,如果最高为j,j又是4,那直接gg,等于0,其余如果j不是6,那么递归的时候无需考虑右边一位是不是2,直接全加,

最后如果j是6,那么右一位除了是2的情况全加,这就是递归方程了。

在如上计算之后,我们可以通过对dp数组中不同的值的拼凑来得到0到某个数的区间内有多少个符合条件的数。

然后知道形如  [0, i )这样的区间内的个数,如果给定任意区间 [a , b],则可以拆分成两个区间相间即[0 , b) - [0 , a)

那么怎么拼凑呢?

比如345这个数,假设a1是最高位3,a2是4,a3是5,

那么我们就取最高位为0,1,2的所有数和,加上最高位为3,次高位为0,1,2,3(4不能选,虽然比5小,但是有4了)的所有之和,再加上。。。类比下去。

代码如下:

#include<iostream>
using namespace std;
#define ll long long
ll dp[][]; void cal_dp()
{
dp[][]=;
for (int i=;i<;i++)
{
for (int j=;j<;j++)
{
if (j==) dp[i][j]=;
else if (j==)
{
for (int k=;k<;k++)
dp[i][j]+=dp[i-][k];
dp[i][j]-=dp[i-][];
}
else
{
for (int k=;k<;k++)
dp[i][j]+=dp[i-][k];
}
}
}
} int a[];
ll solve(int n)
{
a[]=;
while (n)
{
a[++a[]]=n%;
n/=;
}
a[a[]+]=;
ll ans=;
for (int i=a[];i>=;i--)
{
for (int j=;j<a[i];j++)
if (j!= && !(a[i+]== && j==))
ans+=dp[i][j];
if (a[i]==) break;
if (a[i+]== && a[i]==) break;
}
return ans;
} int main()
{
int n,m;
cal_dp();
while (scanf("%d %d",&n,&m)== && (n||m))
{
ll k1=solve(m+);
ll k2=solve(n);
printf("%I64d\n",k1-k2);
}
return ;
}

hdu2089数位DP的更多相关文章

  1. hdu2089 数位dp

    不要62 Time Limit: 1000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Total Submi ...

  2. hdu2089(数位DP 递推形式)

    不要62 Time Limit: 1000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total Submis ...

  3. HDU2089 不要62[数位DP]

    不要62 Time Limit: 1000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total Submis ...

  4. 数位dp入门 hdu2089 不要62

    数位dp入门 hdu2089 不要62 题意: 给定一个区间[n,m] (0< n ≤ m<1000000),找出不含4和'62'的数的个数 (ps:开始以为直接暴力可以..貌似可以,但是 ...

  5. [您有新的未分配科技点]数位dp:从懵X到板子(例题:HDU2089 不要62)

    数位dp主要用来处理一系列需要数数的问题,一般套路为“求[l,r]区间内满足要求的数/数位的个数” 要求五花八门……比如“不出现某个数字序列”,“某种数的出现次数”等等…… 面对这种数数题,暴力的想法 ...

  6. hdu2089:不要62(基础数位dp)

    题意:规定一个合法的号码不能含有4或者是连续的62 给定区间[n,m] 问此区间内合法的号码的个数 分析:数位dp dp[i][j]代表 最高位为 j 的 i 位数有多少个合法的 然后按题目规则进行转 ...

  7. 【数位DP】【HDU2089】不要62

    不要62 Time Limit: 1000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Total Submi ...

  8. hdu2089(数位dp)

    题目连接:http://acm.hdu.edu.cn/showproblem.php?pid=2089 题意:求区间[a,b]内不含有62或4的数的个数. 分析:数位dp,dp[pos][0]表示到第 ...

  9. hdu2089 不要62 我的第一个数位DP

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2089 数位DP的入门题,我是根据kuangbin的博客写出来的 思路: dp[i][0],表示长度为i ...

随机推荐

  1. <Jmeter入门不放弃>之<1.认识jmeter>

    大家这里参考学习的时候,我就不在这里配截图了,因为需要你打开工具根据文档自己去找,,才有印象,大家一定要启动JMeter! 一.Jmeter是什么 由 Apache 组织开发,基于JAVA压力测试工具 ...

  2. Python(二)

    函数Python的函数支持递归.默认参数值.可变参数,但不支持函数重载.为了增强代码的可读性,可以在函数后书写“文档字符串”(Documentation Strings,或者简称docstrings) ...

  3. ASP.NET MVC 分页之 局部视图

    using System; using System.Collections.Generic; using System.Linq; using System.Security.Cryptograph ...

  4. css使子元素在父元素居中的各种方法

    html结构: <div class="parent"> <div class="child"></div> </di ...

  5. 微信公众号的SpringBoot+Quartz的定时任务Demo

    SpringBoot整合quartz并不难,难在普通类实现了Job接口后等于实例化交给quartz,不受Spring管理,则service层等等其他依赖的注入将无法注入,这也是难点之一. 解决方法: ...

  6. php开发面试题---php缓存总结

    php开发面试题---php缓存总结 一.总结 一句话总结: 缓存主要分本地缓存和分布式缓存两种 可以用分布式本地缓存:把那些常用的.不容易变的页面.数据都存下来 1.常用的缓存构架? 分布式本地缓存 ...

  7. Struts1.3——Struts入门

    1.Struts的几个基本概念 1.struts是一个开源框架(frameset) 2.struts是一个Web框架 3.struts是一个基于MVC的Web框架 2.为什么有struts 因为我们对 ...

  8. day 53-1 Django基础三之视图函数

    Django基础三之视图函数   本节目录 一 Django的视图函数view 二 CBV和FBV 三 使用Mixin 四 给视图加装饰器 五 Request对象 六 Response对象 一 Dja ...

  9. 获取项目根目录(非tomact)

    String path; public void main(String[] args) { File file=new File(""); path=file.getAbsolu ...

  10. TreeSet源码解析笔记

    定义: TreeSet是一个有序的集合,它的作用是提供有序的Set集合.它继承了AbstractSet抽象类,实现了NavigableSet<E>,Cloneable,Serializab ...