A5708.数字统计 题解
2023-09-30 21:01:16
发布于:四川
45阅读
0回复
0点赞
思路
数位 dp 板子,很难解释数位 dp。
暴力好似是能解的,Q 群里 dalao 七星松用暴力水过了/hs
代码
#include <iostream>
using namespace std;
int a,b,ten[20],f[20],cnta[20],cntb[20];
void solve(int x,int *cnt){
int 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];
int 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(){
cin >> 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);
cout<<cntb[2]-cnta[2]<<endl;
return 0;
}
这里空空如也
有帮助,赞一个