描述
请统计某个给定范围[L, R]的所有整数中,数字2出现的次数。
比如给定范围[2, 22],数字2在数2中出现了1次,在数12中出现1次,在数20中出现1次,在数21中出现1次,在数22中出现2次,所以数字2在该范围内一共出现了6次。
输入
输入共 1 行,为两个正整数 L 和 R,之间用一个空格隔开。
输出
输出共 1 行,表示数字 2 出现的次数。
样例输入
样例 #1: 2 22 样例 #2: 2 100
样例输出
样例 #1: 6 样例 #2: 20
解析:
循环开始值与结束值给定,都是数字,判断该数字中有没有“2”(或者其他数字都可)
每一次循环的数字都进行内层循环,遍历该数字的每一位,如果有“2”,计数器加一
【思想类似“数字反转”,操作更简单】
代码:
#include <iostream>
using namespace std;
int main()
{
int L, R;
cin >> L >> R;
int count = 0;
for( int i=L; i<=R; i++ )
{
int j = i; //用j来操作,防止循环控制条件i的值产生变化
while( j )
{
if( j%10 == 2 )
count++;
j = j/10;
}
}
cout << count;
return 0;
}