问题描述:求1到2020含有多少个字符2?
问题分解:
(1)求1-100含有字符2的总数:
取个位数:2、12、22、32、42、52、62、72、82、92,总10个
取十位数:20、21、22、23、24、25、26、27、28、29,总10个
即20个。
(2)依次类推:
200-300:20+100
300-400:20
400-500:20
600-700:20
700-800:20
800-900:20
900-1000:20
即1-1000含有字符2的总数:10*20+100=300
(3)则1-2000含有字符2的总数:2*300=600
(4)再来求2000-2020:先看千位数(21个),再求个位数(比如02、12)和十位数(比如20)
2000-2020有21+3=24个字符2
(5)所以1-2020总共有624个字符2。
程序运行:
//求解1-2020含有多少个字符2
#include <iostream>
using namespace std;
int main(int argc, char** argv) {
int s=0,n;
for(int i=1;i<=2020;i++)
{
for(int j=i;j>0;j=j/10)
{
n=j%10;
if(n==2)
{
s++;
cout<<i<<" ";
}
}
}
cout<<endl<<"s="<<s;
return 0;
}
结果: