记录编号 |
578226 |
评测结果 |
AAAAAAAAAA |
题目名称 |
[ZJOI 2010] 数字统计 |
最终得分 |
100 |
用户昵称 |
ムラサメ |
是否通过 |
通过 |
代码语言 |
C++ |
运行时间 |
0.000 s |
提交时间 |
2023-02-20 22:02:08 |
内存使用 |
0.00 MiB |
显示代码纯文本
#include<bits/stdc++.h>
using namespace std;
long long a,b;
long long ten[20],f[20],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(){
freopen("countzj.in","r",stdin);
freopen("countzj.out","w",stdout);
ios::sync_with_stdio(0);
cin.tie(0);
cout.tie(0);
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);
for(int i=0;i<=9;i++){
cout<<cntb[i]-cnta[i]<<" ";
}
return 0;
}