[ZJOI2010]数字计数

Posted ainiyuling

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了[ZJOI2010]数字计数相关的知识,希望对你有一定的参考价值。

题面

数位dp

#include<bits/stdc++.h>
using namespace std;
long long a,b;
long long ten[20],f[20];
long long cnta[20],cntb[20];
void solve(long long x,long long *cnt)

    long long num[20]=0;
    int len=0;
    while(x)
    
        num[++len]=x%10;
        x=x/10;
     
    for(int i=len;i>=1;i--)
    
        for(int j=0;j<=9;j++)
        cnt[j]+=f[i-1]*num[i];
        for(int j=0;j<num[i];j++)
        cnt[j]+=ten[i-1];
        long long num2=0;
        for(int j=i-1;j>=1;j--)
        
            num2=num2*10+num[j];
        
        cnt[num[i]]+=num2+1;
        cnt[0]-=ten[i-1];
     

int main()

    scanf("%lld %lld",&a,&b);
    ten[0]=1;
    for(int i=1;i<=15;i++)
    
        f[i]=f[i-1]*10+ten[i-1];
        ten[i]=10*ten[i-1];
    
    solve(a-1,cnta);
    solve(b,cntb);
    for(int i=0;i<=9;i++)
    printf("%lld ",cntb[i]-cnta[i]);

  

以上是关于[ZJOI2010]数字计数的主要内容,如果未能解决你的问题,请参考以下文章

[ZJOI 2010] 数字计数

P2602 [ZJOI2010]数字计数

[ZJOI2010]数字计数

bzoj1833 [ZJOI2010]count 数字计数

[BZOJ1833][ZJOI2010]count 数字计数

bzoj 1833: [ZJOI2010]count 数字计数