我的代码是一种非常简单的电子数计算方法。它可以正常工作。
#include <iostream>
double e (unsigned int n){
double result, product;
result = 1;
product = 1;
for (unsigned int i = 1; i <= n; i++) {
product *= i;
result += 1/product;
}
return result;
}
int main(){
unsigned int n;
std::cout << "e number" << "\n";
std::cout << "Iteration count = ";
std::cin >> n;
std::cout << n << " iterations => e = " <<
e(n) << "\n";
return 0;
}
输出为:
e number
Iteration count = 2
2 iterations => e = 2.5
e number
Iteration count = 5
5 iterations => e = 2.71667
e number
Iteration count = 225
2225 iterations => e = 2.71828
问题是,当我尝试使用以下代码显示更多的小数(例如15)时, std :: cout.precision(15)<< e(n)<<“ \ n”; 代替
e(n) << "\n";
输出更改为
e number
Iteration count = 2
2 iterations => e = 62.5
e number
Iteration count = 5
5 iterations => e = 62.71666666666667
e number
Iteration count = 225
225 iterations => e = 62.71828182845905
为什么在e值之前输出“ 6”?
答案 0 :(得分:4)
precision是一个函数,它既设置指定的十进制精度,又返回流对象上的前一个精度。因此,以前的精度是6
,直到您的代码将其更改为15。并且由于您将调用内联到打印操作中,因此6
被馈送到输出流。
只需在打印语句之外调用setprecision
。
std::cout.setprecision(15);
std::cout << n << " iterations => e = " << e(n) << std::endl;