热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

使用数位动态规划算法生成包含数字49的数

目录题目来源题目描述输入描述输出描述用例题目解析算法源码题目来源20200817-数位DP-带49的数_哔哩哔哩_bilibili题目描述求区间[1,n]范围内包

目录

题目来源

题目描述

输入描述

输出描述

用例

题目解析

算法源码




题目来源

20200817-数位DP-带49的数_哔哩哔哩_bilibili


题目描述

求区间 [1,n] 范围内包含多少带 49 的数。

一个数是带 49 的数,当且仅当它的十进制表示中存在连续的两位,其中较高位为 4,较低位为 9。

比如:49, 149, 1234987 都是带 49 的数;

而 4, 12345, 94, 999444 都不是。


输入描述

输入一个整数 n (1 ≤ n <2^63)。


输出描述

输出一个整数,表示区间 [1, n] 范围内存在多少带 49 的数。


用例


输入500
输出15
说明


题目解析

本题由于数量级太大,1 ≤ n <2^63,因此不能用暴力枚举,只能用数位DP解决。

本题解题思路和数位DP - 带3的数_伏城之外的博客-CSDN博客

类似,只是数位特征从3变为了49。

也就是说,我们需要关注两级,前一级取值4,后一级取值9,才能满足条件。因此记忆化数组f不仅需要记住某级i下含49数的个数,还需要记住前一级取值是什么,即f需要初始化为二维数组。

f[i][pre],i表示当前级,pre表示上一级的取值。


算法源码

/* Javascript Node ACM模式 控制台输入获取 */
const readline = require("readline");const rl = readline.createInterface({input: process.stdin,output: process.stdout,
});rl.on("line", (line) => {console.log(digitSearch(line));
});function digitSearch(num) {const arr = num.split("").map(Number);// f[i][pre] 表示 第i位,且第i-1位值为pre 的 数中, 不含49的数的个数const f = new Array(arr.length).fill(0).map(() => new Array(10));return num - 0 + 1 - dfs(0, true, f, arr, 0);
}function dfs(p, limit, f, arr, pre) {if (p === arr.length) return 1;if (!limit && f[p][pre]) return f[p][pre];const max = limit ? arr[p] : 9;let count = 0;for (let i = 0; i <= max; i++) {if (i === 9 && pre === 4) continue;count += dfs(p + 1, limit && i === max, f, arr, i);}if (!limit) f[p][pre] = count;return count;
}

推荐阅读
  • 函子(Functor)是函数式编程中的一个重要概念,它不仅是一个特殊的容器,还提供了一种优雅的方式来处理值和函数。本文将详细介绍函子的基本概念及其在函数式编程中的应用,包括如何通过函子控制副作用、处理异常以及进行异步操作。 ... [详细]
  • H5技术实现经典游戏《贪吃蛇》
    本文将分享一个使用HTML5技术实现的经典小游戏——《贪吃蛇》。通过H5技术,我们将探讨如何构建这款游戏的两种主要玩法:积分闯关和无尽模式。 ... [详细]
  • 本文详细介绍了如何在循环双链表的指定位置插入新元素的方法,包括必要的步骤和代码示例。 ... [详细]
  • 文章目录前言Program(程序)Identifier(标识符)Literal(字面量)Vari ... [详细]
  • 1.绑定htmlcss1.1对象语法:  传给v-bind:class一个对象,以动态地切换class   ... [详细]
  • 本文介绍如何使用JavaScript中的for循环来创建一个九九乘法表,适合初学者学习循环结构的应用。 ... [详细]
  • 本文介绍了如何在 Node.js 中使用流(Stream)进行数据读取与写入,包括创建可读流与可写流的基本方法,并提供了具体的代码示例。 ... [详细]
  • 本文详细介绍了`android.os.Binder.getCallingPid()`方法的功能和应用场景,并提供了多个实际的代码示例。通过这些示例,开发者可以更好地理解如何在不同的开发场景中使用该方法。 ... [详细]
  • 解决JavaScript中法语字符排序问题
    在开发一个使用JavaScript、HTML和CSS的Web应用时,遇到从SQLite数据库中提取的法语词汇排序不正确的问题,特别是带重音符号的字母未按预期排序。 ... [详细]
  • 如何从BAM文件绘制ATAC-seq插入片段长度分布图?
    在ATAC-seq数据处理中,插入片段长度的分布图是一个重要的质量控制指标,它能反映出核小体的周期性排列。本文将详细介绍如何从BAM文件中提取并绘制这些数据。 ... [详细]
  • 在OpenCV 3.1.0中实现SIFT与SURF特征检测
    本文介绍如何在OpenCV 3.1.0版本中通过Python 2.7环境使用SIFT和SURF算法进行图像特征点检测。由于这些高级功能在OpenCV 3.0.0及更高版本中被移至额外的contrib模块,因此需要特别处理才能正常使用。 ... [详细]
  • 本文探讨了如何通过Service Locator模式来简化和优化在B/S架构中的服务命名访问,特别是对于需要频繁访问的服务,如JNDI和XMLNS。该模式通过缓存机制减少了重复查找的成本,并提供了对多种服务的统一访问接口。 ... [详细]
  • importjava.io.*;importjava.util.*;publicclass五子棋游戏{staticintm1;staticintn1;staticfinalintS ... [详细]
  • 本文档详细介绍了软通动力Java开发工程师职位的笔试题目,涵盖了Java基础、集合框架、JDBC、JSP等内容,并提供了详细的答案解析。 ... [详细]
  • 本文档详细介绍了购物车系统V0612版中的用户登录机制及购物功能实现方法。 ... [详细]
author-avatar
Cher麻花
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有