鱼C论坛

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

[已解决]捐款题

[复制链接]
发表于 2023-11-7 09:20:28 | 显示全部楼层 |阅读模式

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

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

x
  1. #include <stdio.h>
  2. #define SUM 100000

  3. int main()
  4. {
  5.         float amount, total = 0, aver;
  6.         int i = 1;
  7.         while(i <= 1000)
  8.         {
  9.                 printf("input the amount:\n");
  10.                 scanf("%f", &amount);
  11.                 total = total + amount;
  12.                 i = i++;
  13.                 if(total >= SUM);break;
  14.         }
  15.         aver = total / i;
  16.         printf("num=%d\naver=%10.2f\n", i, aver);
  17.         return 0;
  18. }
复制代码

为什么这个代码达不到目的
最佳答案
2023-11-7 09:21:38
这段代码的目的是让用户输入金额,直到输入的金额总和达到100000,然后输出输入的次数和平均每次输入的金额。

在代码中有一个错误和一个潜在的问题。

1. 首先,#include <stdio.h>#define SUM 100000 这两行之间应该有换行符,否则可能会导致预处理错误。应该修改为:
  
  1.    #include <stdio.h>
  2.    #define SUM 100000
  3.    
复制代码

2. 然后,在 while 循环内部,i = i++; 这行代码的作用不是递增 i 的值,而是将 i 赋值为当前的 i 值,因此循环条件无法得到满足。

   应该将 i = i++; 修改为 i++;,或者直接使用 i += 1;i = i + 1;

另外,循环条件 if(total >= SUM);break; 中的分号应该去掉,否则会导致循环无法正常工作。应该修改为:
  1. if(total >= SUM)
  2.     break;
复制代码

修正后的代码如下所示:
  1. #include <stdio.h>
  2. #define SUM 100000
  3. int main() {
  4.     float amount, total = 0, aver;
  5.     int i = 0;  // 初始化 i 为 0,因为在循环中会先执行 i++
  6.    
  7.     while (i < 1000) {  // 修改循环条件,避免无限循环
  8.         printf("input the amount:\n");
  9.         scanf("%f", &amount);
  10.         total = total + amount;
  11.         i++;  // 修改递增方式
  12.         if (total >= SUM)
  13.             break;
  14.     }
  15.     aver = total / i;
  16.     printf("num=%d\naver=%10.2f\n", i, aver);
  17.     return 0;
  18. }
复制代码

这样修改后的代码应当能够实现预期的功能。

球一个最佳答案谢谢啦!这对我非常重要!
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2023-11-7 09:21:38 | 显示全部楼层    本楼为最佳答案   
这段代码的目的是让用户输入金额,直到输入的金额总和达到100000,然后输出输入的次数和平均每次输入的金额。

在代码中有一个错误和一个潜在的问题。

1. 首先,#include <stdio.h>#define SUM 100000 这两行之间应该有换行符,否则可能会导致预处理错误。应该修改为:
  
  1.    #include <stdio.h>
  2.    #define SUM 100000
  3.    
复制代码

2. 然后,在 while 循环内部,i = i++; 这行代码的作用不是递增 i 的值,而是将 i 赋值为当前的 i 值,因此循环条件无法得到满足。

   应该将 i = i++; 修改为 i++;,或者直接使用 i += 1;i = i + 1;

另外,循环条件 if(total >= SUM);break; 中的分号应该去掉,否则会导致循环无法正常工作。应该修改为:
  1. if(total >= SUM)
  2.     break;
复制代码

修正后的代码如下所示:
  1. #include <stdio.h>
  2. #define SUM 100000
  3. int main() {
  4.     float amount, total = 0, aver;
  5.     int i = 0;  // 初始化 i 为 0,因为在循环中会先执行 i++
  6.    
  7.     while (i < 1000) {  // 修改循环条件,避免无限循环
  8.         printf("input the amount:\n");
  9.         scanf("%f", &amount);
  10.         total = total + amount;
  11.         i++;  // 修改递增方式
  12.         if (total >= SUM)
  13.             break;
  14.     }
  15.     aver = total / i;
  16.     printf("num=%d\naver=%10.2f\n", i, aver);
  17.     return 0;
  18. }
复制代码

这样修改后的代码应当能够实现预期的功能。

球一个最佳答案谢谢啦!这对我非常重要!
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2023-11-7 09:21:54 | 显示全部楼层
这个代码无法达到目的是因为存在几个问题:

1. 在循环中,使用  i = i++;  这个语句是错误的。 i++  表示先使用  i  的值,然后再将  i  的值加1。所以这里应该使用  i++  或者  i = i + 1  来实现  i  的自增。

2. 在  if(total >= SUM);break;  这个语句中,分号  ;  的位置错误。分号应该放在  if  语句的末尾,而不是在条件判断的后面。因此,应该修改为  if(total >= SUM) break; 。

以下是修改后的代码:

  1. #include <stdio.h>
  2. #define SUM 100000

  3. int main()
  4. {
  5.     float amount, total = 0, aver;
  6.     int i = 1;
  7.     while(i <= 1000)
  8.     {
  9.         printf("input the amount:\n");
  10.         scanf("%f", &amount);
  11.         total = total + amount;
  12.         i++;
  13.         if(total >= SUM) break;
  14.     }
  15.     aver = total / i;
  16.     printf("num=%d\naver=%10.2f\n", i, aver);
  17.     return 0;
  18. }
复制代码


这样修改后的代码应该能够正常运行并达到预期的目的。
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-4-22 10:31

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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