|
马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册
x
题目描述
试计算在区间 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
出现的次数。
- #include<stdio.h>
- int main()
- {
- long long n,i,j,x,s=0,a;
- scanf("%lld%lld");
- for(i=1;i<=n;i++)
- {
- for(j=i;j>0;j++)
- {
- a=j%10;
- if(a==1) s++;
- j=j/10;
- }
- }
- printf("%lld",s);
- }
复制代码
你的代码中存在一些问题,这可能是导致输出为零的原因。
1. 在你的 scanf 函数中,你没有指定任何变量来接收输入的值。你应该修改为 scanf(\"%lld%lld\", &n, &x);,这样才能正确地从输入中读取 n 和 x 的值。
2. 在你的代码中,你硬编码了 if(a==1),这意味着你的代码只会计算数字1出现的次数,而不是变量 x。你应该修改为 if(a==x),这样才能正确地计算数字 x 出现的次数。
修改后的代码如下:
- #include<stdio.h>
- int main() {
- long long n, i, j, x, s = 0, a;
- scanf("%lld%lld", &n, &x);
- for(i = 1; i <= n; i++) {
- for(j = i; j > 0; j = j / 10) {
- a = j % 10;
- if(a == x) s++;
- }
- }
- printf("%lld", s);
- return 0;
- }
复制代码
这段代码将会计算在从1到n的所有整数中,数字x出现的次数,并将结果打印出来。
请注意,本回答来自GPT-4
如果问题已经解决,请设置最佳答案
|
|