请统计某个给定范围[L, R]的所有整数中,数字2出现的次数。
比如给定范围[2, 22],数字2在数2中出现了1次,在数12中出现1次,在数20中出现1次,在数21中出现1次,在数22中出现2次,所以数字2在该范围内一共出现了6次。
输入共 1 行,为两个正整数 L 和 R,之间用一个空格隔开。
输出共 1 行,表示数字 2 出现的次数。
2 22
6
样例 #2:
2 100
样例 #2:
20
题解:先把l到r都循环一遍,然后把i赋值给t,然后再把i的数字分解出来,如果t等于二,则就统计次数,之后要不断地除以10,为了避免十位、百位、千位的数也有数字二,如果t本身就是2,除以10之后等于0,则t就小于0,所以下一次就不用执行。
源代码:
#include<iostream>
using namespace std;
int main()
{
long l,r,ans=0;
cin>>l>>r;
for (int i=l;i<=r;i++)
{
long t=i;
while (t>0)
{
if (t%10==2) ans++;
t/=10;
}
}
cout<<ans<<endl;
return 0;
}