原题如下:试计算在区间 1 到 n 的所有整数中,数字 x(0 ≤ x ≤ 9) 共出现了多少次?例如,在 1 到 11 中,即在 1,2,3,4,5,6,7,8,9,10,11 中,数字 1 出现了 4 次。
输入描述:
2 个整数 n,x ,之间用一个空格隔开。
输出描述:
1 个整数,表示 x 出现的次数。
示例
示例1
输入11 1
输出4
我的代码
#include <stdio.h>
int gewei(int a)
{
int b;
b = a % 10;
return b;
}
int shiwei(int a)
{
int b;
b = (a % 100 - gewei(a)) / 10;
return b;
}
int baiwei(int a)
{
int b;
b = (a % 1000 - gewei(a) - shiwei(a) * 10) / 100;
return b;
}
int solution(int m, int n) {
int result;
int i;
int sum=0;
for (i = 1; i <= m; i++)
{
if (i <= 9)
{
if (i == n)sum++;
}
if (i <= 99 && i >= 10)
{
if (gewei(i) == n)
sum++;
if ((i-gewei(i))/10 == n);
sum++;
}
if (i <= 999 && i >= 100)
{
if (gewei(i) == n)
sum++;
if (shiwei(i) == n)
sum++;
if ((i-gewei(i)-shiwei(i)*10)/100 == n)
sum++;
}
if (i >= 1000 && i <= 9999)
{
if (gewei(i) == n)
sum++;
if (shiwei(i) == n)
sum++;
if (baiwei(i) == n)
sum++;
if ((i-gewei(i)-shiwei(i)*10-baiwei(i)*100)/1000 == n)
sum++;
}
}
result = sum;
return result;
}
int main() {
int m;//m是范围
int n;//n是数字
scanf("%d", &m);
scanf("%d", &n);
int result = solution(m, n);
printf("%d", result);
return 0;
}
求教!!!