![](/img/trans.png)
[英]Input n (a positive integer) numbers and work out their sum, average and sum of the squares of the numbers
[英]Sum and average for n numbers with -1 as exit integer
您好,我的代码有一个小问题,我想了解一下。 我的任务是编写一个程序,用 while 循环或嵌套的 while 循环,用 if 条件对 n 个数字求和和求平均值,当你想退出代码时,你应该输入 -1。 代码在下面。 我遇到的问题是我无法从计算中排除 -1 。 我究竟做错了什么。 它假设是一个简单的代码。
int main(void) {
int count;
float sum, average, number;
sum = 0;
count = 0;
printf("Calculate sum and average (-1 to quit)\n");
while (number!=-1) {
scanf("%f", &number);
sum = sum + number;
count = count + 1;
}
average = sum / count;
printf("Sum=%f", sum);
printf(" Average=%f", average);
}
在 while 块中,您读取数字,然后将其添加到您的平均计算中,只有在重复迭代之后,您才检查它是否不同于 -1 以停止迭代:
显然有不同的解决方法:
一种方法是使用 while(true) 并在读取数字后的 while 块中添加一个 if 语句以将其与 -1 进行比较并跳出循环
while (true) {
scanf("%f", &number);
if (number == -1) break;
sum = sum + number;
count = count + 1;
}
重新排序不同的步骤可以解决这个问题:
int main(void) {
int count;
float sum, average, number=0.0f;
sum = 0;
count = -1;
printf("Calculate sum and average (-1 to quit)\n");
while (number!=-1) {
sum = sum + number; // first time no effect with 0
count = count + 1; // first time "no effect" counting to 0
scanf("%f", &number); // will not be counted or summed if -1
}
average = sum / count;
printf("Sum=%f", sum);
printf(" Average=%f", average);
}
立即输入 -1 仔细考虑:
用一个数字来想一想:
顺便说一下,比较浮动的身份是有风险的。 如果你可以更“慷慨地”比较,你会更安全,例如while (number>-0.5)
。
我认为你应该在循环的最后一个输入,因为它会在下一次迭代中得到检查。 当 -1 出现时,它不会被添加。
#include <stdio.h>
int main(){
int count=0;
float sum=0, average=0, number=0;
printf("Calculate sum and average (-1 to quit)\n");
while(number!=-1){
sum = sum + number;
count = count + 1;
scanf("%f", &number);
}
average = sum / count;
printf("Sum=%f", sum);
printf(" Average=%f", average);
}
代码需要将number
测试为 -1,然后才能将其包含在总和中。 OP 的代码测试几乎可以做到这一点。 甚至在分配number
之前 OP 的代码测试-1
会导致未定义的行为(UB)。
float number;
while (number!=-1) { // UB!
测试scanf()
的返回码是否成功也很好。
while (scanf("%f", &number) == 1 && number != -1) {
sum = sum + number;
count = count + 1;
}
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.