题目链接

\(Description\)

求\([l,r]\)中\(0,1,\cdots,9\)每个数字出现的次数(十进制表示)。

\(Solution\)

对每位分别DP。注意考虑前导0: 在最后统计时,把0的答案减掉对应位的即可,在第\(i\)位的前导0会产生额外的\(10^{i-1}\)个答案。

#include <cstdio>
#include <cstring>
#include <algorithm> int Ans[10],A[10],f[10][10],pw[10];
bool vis[10][10]; int DFS(int pos,int cnt,bool lim,int K)
{
if(!pos) return cnt;
if(!lim && vis[pos][cnt]) return f[pos][cnt];
int up=lim?A[pos]:9, res=0;
for(int i=0; i<=up; ++i)
res+=DFS(pos-1,cnt+(i==K),i==up&&lim,K);
if(!lim) vis[pos][cnt]=1,f[pos][cnt]=res;
return res;
} int main()
{
pw[0]=1;
for(int i=1; i<=8; ++i) pw[i]=pw[i-1]*10;
int l,r;
while(scanf("%d%d",&l,&r),l&&r)
{
if(l>r) std::swap(l,r);
for(A[0]=0; r; r/=10) A[++A[0]]=r%10;
for(int i=0; i<=9; ++i)//每个数答案都是不同的。。别忘清空。
memset(vis,0,sizeof vis), Ans[i]=DFS(A[0],0,1,i);
int bit=A[0]; for(A[0]=0,--l; l; l/=10) A[++A[0]]=l%10;
for(int i=0; i<=9; ++i)
memset(vis,0,sizeof vis), Ans[i]-=DFS(A[0],0,1,i);
while(bit!=A[0]) Ans[0]-=pw[--bit];
for(int i=0; i<9; ++i) printf("%d ",Ans[i]);
printf("%d\n",Ans[9]);
}
return 0;
}

数字计数:

//824kb	52ms
//被longlong坑。。
#include <cstdio>
#include <cstring>
#include <algorithm>
typedef long long LL; LL Ans[13],A[13],f[13][13],pw[13];
bool vis[13][13]; LL DFS(int pos,LL cnt,bool lim,int K)
{
if(!pos) return cnt;
if(!lim && vis[pos][cnt]) return f[pos][cnt];
int up=lim?A[pos]:9; LL res=0;
for(int i=0; i<=up; ++i)
res+=DFS(pos-1,cnt+(i==K),i==up&&lim,K);
if(!lim) vis[pos][cnt]=1,f[pos][cnt]=res;
return res;
} int main()
{
pw[0]=1;
for(int i=1; i<=12; ++i) pw[i]=pw[i-1]*10ll;
LL l,r;
scanf("%lld%lld",&l,&r);
if(l>r) std::swap(l,r);
for(A[0]=0; r; r/=10) A[++A[0]]=r%10;
for(int i=0; i<=9; ++i)//每个数答案都是不同的。。别忘清空。
memset(vis,0,sizeof vis), Ans[i]=DFS(A[0],0,1,i);
int bit=A[0]; for(A[0]=0,--l; l; l/=10) A[++A[0]]=l%10;
for(int i=0; i<=9; ++i)
memset(vis,0,sizeof vis), Ans[i]-=DFS(A[0],0,1,i);
while(bit!=A[0]) Ans[0]-=pw[--bit];
for(int i=0; i<9; ++i) printf("%lld ",Ans[i]);
printf("%lld",Ans[9]); return 0;
}

UVA.1640.The Counting Problem / BZOJ.1833.[ZJOI2010]数字计数(数位DP)的更多相关文章

  1. [ZJOI2010]数字计数 数位DP

    最近在写DP,今天把最近写的都放上来好了,,, 题意:给定两个正整数a和b,求在[a,b]中的所有整数中,每个数码(digit)各出现了多少次. 首先询问的是一个区间,显然是要分别求出1 ~ r ,1 ...

  2. [luogu2602 ZJOI2010] 数字计数 (数位dp)

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

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

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

  4. 洛谷P2602 [ZJOI2010]数字计数(数位dp)

    数字计数 题目传送门 解题思路 用\(dp[i][j][k]\)来表示长度为\(i\)且以\(j\)为开头的数里\(k\)出现的次数. 则转移方程式为:\(dp[i][j][k] += \sum_{t ...

  5. UVA 1640 The Counting Problem UVA1640 求[a,b]或者[b,a]区间内0~9在里面各个数的数位上出现的总次数。

    /** 题目:UVA 1640 The Counting Problem UVA1640 链接:https://vjudge.net/problem/UVA-1640 题意:求[a,b]或者[b,a] ...

  6. UVA 1640 The Counting Problem

    https://vjudge.net/problem/UVA-1640 题意:统计区间[l,r]中0——9的出现次数 数位DP 注意删除前导0 #include<cmath> #inclu ...

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

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

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

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

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

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

随机推荐

  1. POJ - 2240 Arbitrage(Bellman-Ford)

    https://vjudge.net/problem/POJ-2240 题意 已知n种货币,以及m种货币汇率及方式,问能否通过货币转换,使得财富增加. 分析 Bellman-Ford判断正环,注意初始 ...

  2. OpenResty 扩展库(二)lua-resty-template

    Lua和OpenResty的模板引擎(HTML) 模板语法 您可以在模板中使用以下标签: {{expression}},写入表达式的结果 - html转义 {*expression*},写入表达结果 ...

  3. 英文写作指南——《“compare to”等同“compare with”吗?》

  4. HTTP 错误 404.0 - Not Found

    当网上的那些修改程序池的方法,无法解决此问题时,可以尝试修改以下的参数: 1.控制面板-->程序-->启用或关闭Windows功能--> Internet Information S ...

  5. Hibernate二级缓存(未完待续)

    1.Hibernate的cache介绍: Hibernate实现了良好的Cache机制,可以借助Hibernate内部的Cache迅速提高系统的数据读取性能.Hibernate中的Cache可分为两层 ...

  6. Install Shield中调用devcon自动安装硬件驱动程序

    1.安装驱动程序命令devcon安装好WINDDK之后,devcon.exe在"C:\WINDDK\3790.1830\tools\devcon"目录下.>devcon up ...

  7. WPF的EventAggregator的发布和订阅

    EventAggregator是Prism中专门处理ViewModel与ViewModel之间事件传递的类对象,它提供了针对事件的发布方法和订阅方法,所以可以非常方便的来管理事件.下面分几步来实现相关 ...

  8. 八、vue使用element-ui组件

    element-ui组件 1.引入element import Vue from 'vue'; import ElementUI from 'element-ui'; import 'element- ...

  9. 使用OpenSSL自建CA + Nginx配置HTTPS

    Ubuntu 16.04(ECS),OpenSSL 1.0.2g  1 Mar 2016,Nginx 1.10.3 (Ubuntu), 浏览器:Chrome 67,Firefox 61,Edge 40 ...

  10. python与C交互中传入与读取内存空间

    使用用python调用c代码中,从外部传入一个固定大小的内存空间,这段内存需要是可写的 首先看下c中的函数 typedef struct ModelData { unsigned int model_ ...