在c ++中具有cout.precision()的奇怪输出

时间:2018-08-12 17:35:47

标签: c++

我的代码是一种非常简单的电子数计算方法。它可以正常工作。

#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”?

1 个答案:

答案 0 :(得分:4)

precision是一个函数,它既设置指定的十进制精度,又返回流对象上的前一个精度。因此,以前的精度是6,直到您的代码将其更改为15。并且由于您将调用内联到打印操作中,因此6被馈送到输出流。

只需在打印语句之外调用setprecision

std::cout.setprecision(15);
std::cout << n << " iterations => e = " << e(n) << std::endl;