[英]using int for float division c++
我是 C++ 的新手,我一直在玩弄迄今为止我学到的东西。 我弄乱了数组,我想出了以下代码
#include <iostream>
using namespace std;
int main()
{
// initializes an array with user defined size
int array_size;
cout << "Enter the amount of number you wish to enter: ";
cin >> array_size;
int arr[array_size];
int i = 0;
int element = 0;
int sum = 0;
float average = 0;
// populates the array with user inputted elements
do
{
cout << "Enter number " << i + 1 << ": ";
cin >> element;
arr[i] = element;
sum = sum + element;
++i;
}
while(i < array_size);
int MAX = arr[0];
for(int i = 1; i < array_size; ++i)
if(arr[i] > MAX)
MAX = arr[i];
int MIN = arr[0];
for(int i = 1; i < array_size; ++i)
if(arr[i] < MIN)
MIN = arr[i];
for(int i = 0; i < array_size - 1; ++i)
average = (average + arr[i])/array_size.0;
cout << "The biggest number that was entered was: " << MAX << endl;
cout << "The smallest number that was entered was: " << MIN << endl;
cout << "The sum of the numbers entered is: " << sum << endl;
cout << "The average of the numbers entered is: " << average << endl;
return 0;
}
我在第 40 行收到一个错误: error: expected ';' before numeric constant
error: expected ';' before numeric constant
我相信它是因为我试图将.0
的浮点除法附加到变量名称,我可以使用array_size
执行浮点除法的任何方式?
您不能将“.0”附加到变量名称。 要将其转换为浮动,请使用转换语法:
average = float(average + arr[i]) / float(array_size);
一定要尽早转换,这样你就不会将结果舍入为 int:
average = float(average + arr[i] / array_size); // might not work as expected
更多关于类型转换: http : //www.cplusplus.com/doc/tutorial/typecasting/
顺便说一句,如果您想为平均值添加一个数字,您可能需要使用不同的公式: https : //math.stackexchange.com/a/957376
只需执行操作——每当您对float
变量进行算术运算时,操作数将自动转换为double
float
来执行操作。 所以你只需要:
for(int i = 0; i < array_size - 1; ++i)
average = (average + arr[i])/array_size;
由于average
的类型为float
,因此它和arr[i]
都将被转换为 double 以进行(双精度)浮点加法。 然后,由于该结果是double
, array_size
也将被转换为double
并进行浮点除法。 最后, double
float
结果将被转换回float
并存储在average
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.