此题感觉良好哦!
#include <iostream>
using namespace std;
#include<cmath>
int a[10],b[10],e[10]={0,1,20,300,4000};
int f(int r)
{
int j=0,k=1,s=0,m=0,i;
while(r) {a[j++]=r%10;r/=10;}
for(i=0;i<j;i++)
{m+=a[i]*k;k=k*10;b[i]=m;}
for(i=j-1;i>=1;i--)
if(a[i]==2) s+=a[i]*e[i]+b[i-1]+1;
else if(a[i]<2) s+=a[i]*e[i];
else s+=a[i]*e[i]+pow(10.0,double(i));
if(a[0]>=2) s++;
return s;
}
int main()
{
int l,r;
cin>>l>>r;l--;
cout<<f(r)-f(l)<<endl;
return 0;
}