链接:https://ac.nowcoder.com/acm/contest/19859/A
来源:牛客网
题目描述
请统计某个给定范围[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
输出
6
示例2
输入
2 100
输出
20
备注:
1≤L≤R≤10000。
解决方案
#include<stdio.h>
int func(int n)
{
int x,c=0;
while(n)//数每一位都要判断
{
x=n%10;
n/=10;
if(x==2)
c++;
}
return c;
}
int main()
{
int l,r;
scanf("%d %d",&l,&r);
int i,count=0;
for(i=l;i<=r;i++)
{
count+=func(i);//对范围内的每一个数进行判断是否出现2
}
printf("%d",count);
return 0;
}