不要62

Time Limit: 1000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)
Total Submission(s): 64682    Accepted Submission(s):
25712

Problem Description
杭州人称那些傻乎乎粘嗒嗒的人为62(音:laoer)。
杭州交通管理局经常会扩充一些的士车牌照,新近出来一个好消息,以后上牌照,不再含有不吉利的数字了,这样一来,就可以消除个别的士司机和乘客的心理障碍,更安全地服务大众。
不吉利的数字为所有含有4或62的号码。例如:
62315
73418
88914
都属于不吉利号码。但是,61152虽然含有6和2,但不是62连号,所以不属于不吉利数字之列。
你的任务是,对于每次给出的一个牌照区间号,推断出交管局今次又要实际上给多少辆新的士车上牌照了。
 
Input
输入的都是整数对n、m(0<n≤m<1000000),如果遇到都是0的整数对,则输入结束。
 
Output
对于每个整数对,输出一个不含有不吉利数字的统计个数,该数值占一行位置。
 
Sample Input
1 100
0 0
 
Sample Output
80
 
数位dp入门:
dp[i][j]表示从右往左数第i位上以j开头的 符合要求的数有多少个
dp[i][j]是对dp[i-1][k]的累加,满进
举例说明:

3253
dp[4][0] 0000-0999
dp[4][1] 1000-1999
dp[4][2] 2000-2999 3000

dp[3][0] 0000-0099
dp[3][1] 0100-0199 200

dp[2][0] 0000-0009
dp[2][1] 0010-0019
dp[2][2] 0020-0029
dp[2][3] 0030-0039
dp[2][4] 0040-0049 50

dp[1][0] 0
dp[1][1] 1
dp[1][2] 2 3 一共表示0-3252这3253个数中符合要求的数有多少个

2403
dp[4][0] 0000-0999
dp[4][1] 1000-1999

dp[3][0] 0000-0099
dp[3][1] 0100-0199
dp[3][2] 0200-0299
dp[3][3] 0300-0399
break; 遇到本位是4则后面的位数都不用算了

2623
dp[4][0] 0000-0999
dp[4][1] 1000-1999 2000

dp[3][0] 0000-0099
dp[3][1] 0100-0199
dp[3][2] 0200-0299
dp[3][3] 0300-0399
dp[3][4] 0400-0499
dp[3][5] 0500-0599 600

dp[2][0] 0000-0009
dp[2][1] 0010-0019 20
break; 遇到本位是2,上一位是6的后面的位数也不用算了

2003
dp[4][0] 0000-0999
dp[4][1] 1000-1999 2000

dp[1][0] 0
dp[1][1] 1
dp[1][2] 2 3 遇到本位是0的直接跳过,没有满进到1就用不了dp[3][0]和dp[2][0]

#include<cstring>
#include<algorithm>
#include<stdio.h>
#include<iostream>
#define ll long long
#define inf 0x3f3f3f3f
using namespace std; int dp[][];
int a[]; void init()
{
memset(dp,,sizeof(dp));
dp[][]=;
for(int i=;i<;i++)
{
for(int j=;j<;j++)
{
if(j==) continue;
for(int k=;k<;k++)
{
if(j== && k==) continue;
dp[i][j]+=dp[i-][k];
}
}
}/*打印dp表看看啥情况
for(int i=0;i<10;i++)
{
for(int j=0;j<10;j++)
{
printf("%10d",dp[i][j]);
}
printf("\n");
}*/
} int slove(int x)
{
int cnt=;
int temp=x;
while(x)
{
x=x/;
cnt++;
}
x=temp;
memset(a,,sizeof(a));///a数组从下标1到cnt顺序存储各个位上的数字,人性化
for(int i=cnt;i>=;i--)
{
a[i]=x%;
x=x/;
}
int sum=;for(int i=;i<=cnt;i++)///数组下标从小到大
{
int c=a[i]; for(int j=;j<c;j++)
{
if(a[i-]== && j==) continue;
sum+=dp[ cnt+-i ][j];
}
if(c== || (c== && a[i-]==) )
break;
}
return sum;
} int main()
{
init();
int n,m;
while( scanf("%d %d",&n,&m) && (n+m) )
{
int ans=slove(m+)-slove(n);
printf("%d\n",ans);
}
return ;
}
 

hdu2089-不要62-(数位dp)的更多相关文章

  1. HDU2089 不要62[数位DP]

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

  2. HDU2089 不要62 —— 数位DP

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2089 不要62 Time Limit: 1000/1000 MS (Java/Others)    M ...

  3. hdu2089不要62(数位dp)

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

  4. 【Hdu2089】不要62(数位DP)

    Description 题目大意:给定区间[n,m],求在n到m中没有"62"或"4"的数的个数. 如62315包含62,88914包含4,这两个数都是不合法的 ...

  5. HDU 2089 - 不要62 - [数位DP][入门题]

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2089 Time Limit: 1000/1000 MS (Java/Others) Memory Li ...

  6. HDU 2089 不要62(数位DP&#183;记忆化搜索)

    题意  中文 最基础的数位DP  这题好像也能够直接暴力来做   令dp[i][j]表示以 j 开头的 i 位数有多少个满足条件 那么非常easy有状态转移方程 dp[i][j] = sum{ dp[ ...

  7. [hdu 2089] 不要62 数位dp|dfs 入门

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2089 题意:求[n, m]区间内不含4和62的数字个数. 这题有两种思路,直接数位dp和dfs 数位d ...

  8. Hdu 2089 不要62 (数位dp入门题目)

    题目链接: Hdu 2089 不要62 题目描述: 给一个区间 [L, R] ,问区间内不含有4和62的数字有多少个? 解题思路: 以前也做过这个题目,但是空间复杂度是n.如果数据范围太大就GG了.今 ...

  9. HDU 2089 不要62 数位DP模板题

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2089 参考博客:https://www.cnblogs.com/HDUjackyan/p/914215 ...

  10. hdu-2089 不要62 基础DP 模板

    http://acm.hdu.edu.cn/showproblem.php?pid=2089 数位DP的思想时预处理以x开头长度为len的数(例如 x000~x999)的所有情况.给出一个数,可以在l ...

随机推荐

  1. Oracle之 dmp导入/导出、数据库操作等过程中的字符集问题

    影响Oracle数据库字符集最重要的参数是NLS_LANG参数. 它的格式如下: NLS_LANG = language_territory.charset 它有三个组成部分(语言.地域和字符集),每 ...

  2. Zookeeper之入门(原理、基础知识)

    Zookeeper介绍 Zookeeper是分布式应用程序的协调服务框架,是Hadoop的重要组件.ZK要解决的问题: 1.分布式环境下的数据一致性. 2.分布式环境下的统一命名服务 3.分布式环境下 ...

  3. Python全栈之路----常用模块----time模块

    time 模块的方法 time.time():返回当前时间的时间戳. >>> import time >>> time.time() #从1974年到现在过去了多少 ...

  4. APPlication,Session和Cookie的区别

    方法 信息量大小 保存时间 应用范围 保存位置 Application 任意大小 整个应用程序的生命期 所有用户 服务器端 Session 小量,简单的数据 用户活动时间+一段延迟时间(一般为20分钟 ...

  5. 初始化 CSS 样式

    为什么要初始化 CSS 样式 因为浏览器的兼容问题,不同浏览器对有些标签的默认值是不同的,如果没对 CSS 初始化往往会出现浏览器之间的页面显示差异. 当然,初始化样式会对 SEO 有一定的影响,但鱼 ...

  6. 软件工程第四次作业 石墨文档IOS

    待分析的产品:石墨文档IOS客户端 作业地址: https://edu.cnblogs.com/campus/nenu/2016CS/homework/2505   第一部分 调研, 评测 1.下载并 ...

  7. Web服务器之Nginx详解(操作部分)

    大纲 一.前言 二.Nginx 安装与配置 三.Nginx 配置文件详解 四.Nginx 命令参数 五.配置Nginx提供Web服务 六.配置Nginx的虚拟主机 七.配置Nginx的用户认证 八.配 ...

  8. Redis无法启动

    我的原因是:没有足够的可用空间 以往双击redis-server.exe就可以启动,但突然启动不了,只是弹出控制台一闪而过,之后就自动关闭了, 因为没看到具体错误,百度了下关键字”Redis无法启动“ ...

  9. vs+qt 运行过程出现cannot run rc.exe

    刚开始,我按照网上的一堆教程在qt creator中设置了各种东西,设置完以后,运行时出现cannot run rc.exe,根据百度,将C:\Program Files (x86)\Windows ...

  10. python:学习自顶向下程序设计:竞技体育模拟

    学习过程记录: 一,需求及框架: 二:程序代码: #sports.py from random import random def main(): #熟悉函数的调用 printInfo() probA ...