HDU 2089 不要62(数位DP·记忆化搜索)

简介:

题意  中文

最基础的数位DP  这题好像也能够直接暴力来做   令dp[i][j]表示以 j 开头的 i 位数有多少个满足条件  

那么非常easy有状态转移方程 dp[i][j] = sum{ dp[i-1][k] }, k = 0...9, j != 4 && !( j == 6 && k == 2) 

最后统计个数即可了

#include <bits/stdc++.h>
using namespace std;
int dp[8][10];

int dfs(int i, int j) //记忆化搜索统计以 j 开头的 i 位数满足条件的个数
{
    if(dp[i][j] > -1) return dp[i][j];

    dp[i][j] = 0;
    for(int k = 0; k < 10; ++k)
    {
        if(j == 4 || (j == 6 && k == 2)) continue;
        dp[i][j] += dfs(i - 1, k);
    }
    return dp[i][j];
}

int getNum(int a) //统计[0,a)这个区间满足条件的数的个数
{
    int s[10] = {0};
    int i = 0, ret = 0;
    while(a)
    {
        s[i++] = a % 10;
        a /= 10;
    }

    while(i--)
    {
        for(int j = 0; j < s[i]; ++j)
            if(!(j == 2 && s[i + 1] == 6))
                ret += dfs(i + 1, j);
        if(s[i] == 4 || (s[i] == 2 && s[i + 1] == 6))
            break;    //已经不满足条件了
    }
    return ret;
}

int main()
{
    memset(dp, -1, sizeof(dp));
    for(int i = 0; i < 10; ++i) dp[1][i] = (i != 4); //边界

    int n, m;
    while(scanf("%d%d", &n, &m), n || m)
        printf("%d\n", getNum(m + 1) - getNum(n));

    return 0;
}
//Last modified :   2015-07-22 15:22

不要62



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
 








本文转自mfrbuaa博客园博客,原文链接:http://www.cnblogs.com/mfrbuaa/p/5397822.html,如需转载请自行联系原作者 
相关文章
|
开发工具 C语言 Windows
【Qt 学习笔记】Qt 开发环境的搭建 | Qt 安装教程
【Qt 学习笔记】Qt 开发环境的搭建 | Qt 安装教程
1751 0
|
API Android开发 开发者
Android 12 适配指南——SplashScreen
Android 12(API 31)引入了 SplashScreen 相关API,用于开发Android应用的启动页。 SplashScreen相关API的引入影响在Andorid 12设备上运行的所有应用。若开发者未进行SplashScreen的适配工作,在应用冷启动和温启动时,可能会呈现两个启动页先后出现的情况(Android SplashScreen启动页 + Android应用自定义开发的启动页或引导页)。
2849 0
Android 12 适配指南——SplashScreen
|
开发框架 Android开发 iOS开发
安卓与iOS开发中的跨平台策略:一次编码,多平台部署
在移动应用开发的广阔天地中,安卓和iOS两大阵营各占一方。随着技术的发展,跨平台开发框架应运而生,它们承诺着“一次编码,到处运行”的便捷。本文将深入探讨跨平台开发的现状、挑战以及未来趋势,同时通过代码示例揭示跨平台工具的实际运用。
409 3
|
存储 Java 索引
【数据结构】链表从实现到应用,保姆级攻略
本文详细介绍了链表这一重要数据结构。链表与数组不同,其元素在内存中非连续分布,通过指针连接。Java中链表常用于需动态添加或删除元素的场景。文章首先解释了单向链表的基本概念,包括节点定义及各种操作如插入、删除等的实现方法。随后介绍了双向链表,说明了其拥有前后两个指针的特点,并展示了相关操作的代码实现。最后,对比了ArrayList与LinkedList的不同之处,包括它们底层实现、时间复杂度以及适用场景等方面。
410 10
【数据结构】链表从实现到应用,保姆级攻略
|
存储 缓存 NoSQL
京东面试:亿级黑名单 如何设计?亿级查重 呢?(答案含:布隆过滤器、布谷鸟过滤器)
尼恩,40岁的老架构师,近期在读者交流群中分享了几个大厂面试题及其解决方案。这些问题包括亿级数据查重、黑名单存储、电话号码判断、安全网址判断等。尼恩给出了三种解决方案:使用BitMap位图、BloomFilter布隆过滤器和CuckooFilter布谷鸟过滤器。这些方法不仅高效,还能显著提升面试表现。尼恩还建议大家系统化学习,刷题《尼恩Java面试宝典PDF》,并提供简历修改和面试辅导,帮助大家实现“offer自由”。更多技术资料和PDF可在公众号【技术自由圈】获取。
|
存储 数据采集 数据处理
Pandas中批量转换object至float的高效方法
在数据分析中,常需将Pandas DataFrame中的object类型列转换为float类型以进行数值计算。本文介绍如何使用`pd.to_numeric`函数高效转换,并处理非数字值,包括用0或平均值填充NaN值的方法。
960 1
|
安全 Java 开发者
Java中的并发编程优化技巧
在当今软件开发领域,多核处理器和分布式系统的普及使得并发编程成为了必不可少的技能。本文将介绍一些Java中的并发编程优化技巧,涵盖了线程管理、锁机制、并发集合等方面的内容,帮助开发者更好地应对并发编程中的挑战。
|
Java 区块链
使用Java实现区块链智能合约
使用Java实现区块链智能合约
|
缓存 前端开发 JavaScript
前端 JS 经典:构建工具
前端 JS 经典:构建工具
374 0
|
存储 JSON 数据安全/隐私保护
Flask Python:如何获取不同请求方式的参数
Flask Python:如何获取不同请求方式的参数
1138 0

热门文章

最新文章