鱼C论坛

 找回密码
 立即注册
查看: 793|回复: 5

[已解决]这个是求1000个人内捐款,达到 100000就不捐了,并求捐款人数和平均捐款量,我这个程

[复制链接]
发表于 2024-2-15 17:16:57 | 显示全部楼层 |阅读模式

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

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

x
#include <stdio.h>
int main()
{
  double u=0,m=0,v=0;
  int n=1;
  while(n<=1000)
  {
        scanf("%lf\n",&m);
    n++;
        u=u+m;
        if(u>=100000)
        {
         printf("%d\n",n);
     v=u/n;
     printf("%lf\n",v);
        } break;
  }
return 0;
}
这个是求1000个人内捐款,达到 100000就不捐了,并求捐款人数和平均捐款量,我这个程序哪 里有问题
最佳答案
2024-2-15 18:25:24
您的程序中的问题是`break`语句的位置放在了`if`语句的外面,这样会导致无论`if`条件是否满足,程序都会在第一次循环后跳出循环。你应当将`break`语句放在`if`语句内部。另外,您可能想要将`n++`放在`if`语句之后,因为如果已经达到或超过100000,那么其实您不应该再增加捐款人数。

这是修改后的程序:
#include <stdio.h>
int main()
{
  double u=0,m=0,v=0;
  int n=0;
  while(n<1000)
  {
        scanf("%lf",&m);
        u=u+m;
        n++;
        if(u>=100000)
        {
            v=u/n;
            printf("%d\n",n);
            printf("%lf\n",v);
            break;
        }
  }
return 0;
}

求最佳答案
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2024-2-15 17:17:11 | 显示全部楼层
你的程序中有几个问题:

1. 在while循环条件中,你使用了单个等号(=)来进行赋值操作,而不是双等号(==)进行判断是否相等。应该使用双等号来判断n是否等于100000。

2. 你使用了break语句放在了while循环后面,这样的话循环只会执行一次就退出了。应该将break语句放在if条件判断中,当捐款总额达到100000时跳出循环。

3. 在每次循环中,你没有更新捐款总额u和捐款人数m的值。应该在用户输入捐款金额后更新这两个变量的值。

下面是修改后的代码:
#include <stdio.h>

int main() {
    double u = 0, m = 0;
    int n = 0;
    while (u < 100000) {
        double donation;
        printf("请输入捐款金额:");
        scanf("%lf", &donation);
        u += donation;
        n++;
        if (u >= 100000) {
            break;
        }
    }

    double averageDonation = u / n;
    printf("捐款人数:%d\n", n);
    printf("平均捐款金额:%lf\n", averageDonation);

    return 0;
}

这段代码会在循环中不断地让用户输入捐款金额,直到捐款总额达到或超过100000为止。最后输出捐款人数和平均捐款金额。

以上回复来自 FishC AI 小助理,如未能正确解答您的问题,请继续追问。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2024-2-15 17:23:42 | 显示全部楼层
break写在循环外了,其他没看出来
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2024-2-15 17:34:35 | 显示全部楼层
不应该是达到1000就不捐款了吗?
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2024-2-15 18:25:24 | 显示全部楼层    本楼为最佳答案   
您的程序中的问题是`break`语句的位置放在了`if`语句的外面,这样会导致无论`if`条件是否满足,程序都会在第一次循环后跳出循环。你应当将`break`语句放在`if`语句内部。另外,您可能想要将`n++`放在`if`语句之后,因为如果已经达到或超过100000,那么其实您不应该再增加捐款人数。

这是修改后的程序:
#include <stdio.h>
int main()
{
  double u=0,m=0,v=0;
  int n=0;
  while(n<1000)
  {
        scanf("%lf",&m);
        u=u+m;
        n++;
        if(u>=100000)
        {
            v=u/n;
            printf("%d\n",n);
            printf("%lf\n",v);
            break;
        }
  }
return 0;
}

求最佳答案
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2024-2-15 21:32:08 | 显示全部楼层
你的n++的位置和我的n++位置有什么区别,n++是先运算后加一,我就搞不懂什么时候参加运算,参加什么运算,是后面的运算吗?到什么位置
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-12-22 19:05

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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