鱼C论坛

 找回密码
 立即注册
查看: 2040|回复: 2

[已解决]为什么没有输出啊

[复制链接]
发表于 2023-10-16 11:04:29 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
题目描述
输入一个正整数n
,试计算从1到n
的所有整数中,出现1的次数有多少?例如当n=12
时,有1,2,3,4,5,6,7,8,9,10,11,12,一共出现了5个1。

输入描述
输入一个正整数n
(1≤n≤10000
)。

输出描述
输出一个整数,即出现1的次数。
  1. #include<stdio.h>
  2. int main()
  3. {
  4.     int n,a,s=0;scanf("%d",&n);
  5.     for(int i=1;i<=n;i++)
  6.     {
  7.         while(i>0)
  8.         {
  9.             a=i%10;
  10.             if(a==1){s++;}
  11.             i=i/10;
  12.         }
  13.     }
  14.     printf("%d",s);
  15. }
复制代码
最佳答案
2023-10-16 11:04:50
这段代码的问题在于,在第二个while循环中,它修改了变量i的值,导致后面的循环出现问题。可以使用一个临时变量来存储i的值,而不是直接修改i的值。以下是修改后的代码:

  1. #include <stdio.h>

  2. int main()
  3. {
  4.     int n, a, s = 0;
  5.     scanf("%d", &n);
  6.     for (int i = 1; i <= n; i++)
  7.     {
  8.         int temp = i; // 临时变量
  9.         while (temp > 0)
  10.         {
  11.             a = temp % 10;
  12.             if (a == 1)
  13.             {
  14.                 s++;
  15.             }
  16.             temp = temp / 10;
  17.         }
  18.     }
  19.     printf("%d", s);
  20.     return 0;
  21. }
复制代码


这段代码应该可以正确地计算出从1到n的所有整数中,出现1的次数有多少。
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2023-10-16 11:04:50 | 显示全部楼层    本楼为最佳答案   
这段代码的问题在于,在第二个while循环中,它修改了变量i的值,导致后面的循环出现问题。可以使用一个临时变量来存储i的值,而不是直接修改i的值。以下是修改后的代码:

  1. #include <stdio.h>

  2. int main()
  3. {
  4.     int n, a, s = 0;
  5.     scanf("%d", &n);
  6.     for (int i = 1; i <= n; i++)
  7.     {
  8.         int temp = i; // 临时变量
  9.         while (temp > 0)
  10.         {
  11.             a = temp % 10;
  12.             if (a == 1)
  13.             {
  14.                 s++;
  15.             }
  16.             temp = temp / 10;
  17.         }
  18.     }
  19.     printf("%d", s);
  20.     return 0;
  21. }
复制代码


这段代码应该可以正确地计算出从1到n的所有整数中,出现1的次数有多少。
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2023-10-16 11:05:18 | 显示全部楼层
代码中存在一个逻辑错误。在循环中,你使用了变量 i 作为计数器,并且通过不断地将其除以 10 来遍历每一位数字。然而,在循环的内部,你又修改了 i 的值来进行下一次的迭代,这会导致循环的条件出现问题。

要解决这个问题,你可以使用另一个变量 j 来进行迭代,而保持 i 的值不变。以下是修正后的代码:

  1. #include <stdio.h>

  2. int main() {
  3.     int n, s = 0;
  4.     scanf("%d", &n);
  5.    
  6.     for (int i = 1; i <= n; i++) {
  7.         int j = i;
  8.         while (j > 0) {
  9.             int a = j % 10;
  10.             if (a == 1) {
  11.                 s++;
  12.             }
  13.             j /= 10;
  14.         }
  15.     }
  16.    
  17.     printf("%d", s);
  18.    
  19.     return 0;
  20. }
复制代码


这样修改后,代码将正确计算从 1 到 n 之间所有整数中出现 1 的次数。请注意,该算法的时间复杂度为 O(nlogn),因为对于每个数字 i,我们需要按照它的位数执行迭代操作。
请注意,本回答来自GPT-3.5
如果问题已经解决,请设置最佳答案
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-6-9 12:25

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表