题目链接

做的第一道数位DP题,听说是最基础的模板题,但还是花了好长时间才写出来。。。。。

想深入了解下数位DP的请点这里

先设dp数组dp[i][j][k]表示数位是i,以j开头的数k出现的次数

有 

数位dp的题一般都会用到前缀数组,题目要求我们求b-a这个区间里各个数码出现的次数,我们可以分别求出(0,b)和(0,a-1)然后相减即可

具体分析请看代码,写的还算详细

 #include <bits/stdc++.h>
using namespace std;
typedef long long ll;
ll dp[][][];
ll ans[];//用来储存每个数码出现的次数
ll bin[];//表示i位数中数码i出现的次数
ll d[];//这个用来存储数的每一位
void rule(){
bin[]=;
for(int i=;i<;i++) bin[i]=bin[i-]*;
for(int i=;i<;i++) dp[][i][i]=;
for(int i=;i<=;i++){
for(int j=;j<=;j++){
for(int z=;z<=;z++){
for(int k=;k<=;k++)
dp[i][j][z]+=dp[i-][k][z];//比如i=2,j=2时,所求数字范围应该是200-299,这一步把0-99中各数码出现次数加进去
dp[i][z][z]+=bin[i-];//这一位这是把200-299总共出现了100次的2给加进去
}
}
}
}
void solve(ll x,int flag){
ll tmpx=x;//存储传进来的x
int cnt=;//记录x的位数
memset(d,,sizeof(d));
while(x){
d[++cnt]=x%;
x/=;
}
for(int i=;i<cnt;i++){//这一步是最高位为0的,这些数都不会受到x的上限限制,都可以直接加进来
for(int j=;j<=;j++){
for(int k=;k<=;k++)
ans[k]+=dp[i][j][k]*flag;
}
}
int tmpt=cnt;
while(cnt){//可以举个456的例子来仔细分析一下
for(int i=;i<d[cnt];i++){//注意这里是小于不是等于,保证上限不被取到,在后面再被处理
if(!i&&cnt==tmpt) continue;//这种情况在最高位为0时已经统计过了,不能重复
for(int j=;j<=;j++){
ans[j]+=dp[cnt][i][j]*flag;//不是上限的时候都直接加
}
}
ans[d[cnt]]+=(tmpx%bin[cnt]+)*flag;cnt--;//随着while循环,上限一步步的被处理
}//简述一下过程(456),就是第一个for处理了0-399,然后把首位4的57次加上,第二个for,处理的0-49......就这样一步步往下
}
int main(){
ll a,b;scanf("%lld%lld",&a,&b);
rule();
solve(b,);solve(a-,-);//1和-1是符号位,分别是加和减
for(int i=;i<;i++)
printf("%lld%c",ans[i],i==?'\n':' ');
return ;
}

BZOJ 1833 数字计数 数位DP的更多相关文章

  1. UVA.1640.The Counting Problem / BZOJ.1833.[ZJOI2010]数字计数(数位DP)

    题目链接 \(Description\) 求\([l,r]\)中\(0,1,\cdots,9\)每个数字出现的次数(十进制表示). \(Solution\) 对每位分别DP.注意考虑前导0: 在最后统 ...

  2. 1833: [ZJOI2010]count 数字计数——数位dp

    传送门:http://www.lydsy.com/JudgeOnline/problem.php?id=1833 省选之前来切一道裸的数位dp.. 题意 统计[a,b]中0~9每个数字出现的次数(不算 ...

  3. 【BZOJ-1833】count数字计数 数位DP

    1833: [ZJOI2010]count 数字计数 Time Limit: 3 Sec  Memory Limit: 64 MBSubmit: 2494  Solved: 1101[Submit][ ...

  4. [BZOJ 1833] 数字计数

    Link: BZOJ 1833 传送门 Solution: 比较明显的数位DP 先预处理出1~9和包括前导0的0的个数:$pre[i]=pre[i-1]*10+10^{digit-1}$ (可以分为首 ...

  5. bzoj1833: [ZJOI2010]count 数字计数(数位DP+记忆化搜索)

    1833: [ZJOI2010]count 数字计数 题目:传送门 题解: 今天是躲不开各种恶心DP了??? %爆靖大佬啊!!! 据说是数位DP裸题...emmm学吧学吧 感觉记忆化搜索特别强: 定义 ...

  6. [bzoj1833][ZJOI2010]count 数字计数——数位dp

    题目: (传送门)[http://www.lydsy.com/JudgeOnline/problem.php?id=1833] 题解: 第一次接触数位dp,真的是恶心. 首先翻阅了很多很多一维dp,因 ...

  7. 【题解】P2602 数字计数 - 数位dp

    P2602 [ZJOI2010]数字计数 题目描述 给定两个正整数 \(a\) 和 \(b\) ,求在 \([a,b]\) 中的所有整数中,每个数码(digit)各出现了多少次. 输入格式 输入文件中 ...

  8. bzoj1833: [ZJOI2010]count 数字计数 数位dp

    bzoj1833 Description 给定两个正整数a和b,求在[a,b]中的所有整数中,每个数码(digit)各出现了多少次. Input 输入文件中仅包含一行两个整数a.b,含义如上所述. O ...

  9. Luogu P2602 [ZJOI2010]数字计数 数位DP

    很久以前就...但是一直咕咕咕 思路:数位$DP$ 提交:1次 题解:见代码 #include<cstdio> #include<iostream> #include<c ...

随机推荐

  1. Java 使用命令对堆线程分析

    一.dump基本概念 在故障定位(尤其是out of memory)和性能分析的时候,经常会用到一些文件来帮助我们排除代码问题.这些文件记录了JVM运行期间的内存占用.线程执行等情况,这就是我们常说的 ...

  2. CentOS7.2中systemctl的使用

    CentOS 7.x开始,CentOS开始使用systemd服务来代替daemon,原来管理系统启动和管理系统服务的相关命令全部由systemctl命令来代替. 1.原来的 service 命令与 s ...

  3. SQL优化参考

    1.对查询进行优化,要尽量避免全表扫描,首先应考虑在 where 及 order by 涉及的列上建立索引. 2.应尽量避免在 where 子句中对字段进行 null 值判断,否则将导致引擎放弃使用索 ...

  4. [JavaScript] - replaceAll,将字符串中的字母或数字等全部替换掉的方式

    原题 function DNAtoRNA(dna) { // create a function which returns an RNA sequence from the given DNA se ...

  5. (转载)Windows下小狼毫输入法(Rime)的安装与配置(含导入搜狗词库)

    div id="cnblogs_post_body" class="blogpost-body"> 最近彻底烦透了搜狗拼音输入法的各种流氓行为,自动升级不 ...

  6. 【Hadoop 分布式部署 九:分布式协作框架Zookeeper架构 分布式安装部署 】

    1.首先将运行在本地上的  zookeeper 给停止掉 2.到/opt/softwares 目录下  将  zookeeper解压到  /opt/app 目录下 命令:  tar -zxvf zoo ...

  7. kubernetes 实战6_命令_Share Process Namespace between Containers in a Pod&Translate a Docker Compose File to Kubernetes Resources

    Share Process Namespace between Containers in a Pod how to configure process namespace sharing for a ...

  8. ZooKeeper分布式过程协同技术详解1——ZooKeeper的概念和基础

    简介 分布式系统和应用,不仅能提供更强的计算能力,还能为我们提供更好的容灾性和扩展性. ZooKeeper是Google的Chubby项目的开源实现,它曾经作为Hadoop的子项目,在大数据领域得到广 ...

  9. PTA 7-2 二叉搜索树的结构(30 分)

    7-2 二叉搜索树的结构(30 分) 二叉搜索树或者是一棵空树,或者是具有下列性质的二叉树: 若它的左子树不空,则左子树上所有结点的值均小于它的根结点的值:若它的右子树不空,则右子树上所有结点的值均大 ...

  10. SAP FI CO模块常用事务代码

                                                                                                        ...