此题感觉良好哦!#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;
}
本文介绍了一个使用 C++ 实现的数学算法,该算法通过处理输入的两个整数范围内的数值来计算特定数学序列的差值。代码中包含了对输入数字进行位运算和数学计算的过程,并利用了标准库中的数学函数。
530

被折叠的 条评论
为什么被折叠?



