在 c++ 中使用 cout.precision() 的奇怪输出
Weird output with cout.precision() in c++
我的代码是一种非常简单的e数计算方法。它可以毫无问题地工作。
#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( <<""; 而不是
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"?
精度是一个函数,它既设置指定的十进制精度,又返回流对象的先前精度。 因此,在代码将其更改为 15 之前,以前的精度是6
的。 由于您将调用内联到打印操作中,因此6
将馈送到输出流。
只需在打印语句之外调用setprecision
即可。
std::cout.setprecision(15);
std::cout << n << " iterations => e = " << e(n) << std::endl;
相关文章:
- 递归函数计算序列中的平方和(并输出过程)
- 如何使用 < 和 > 命令获取 c++ 中的输入和输出?
- 请解释"函数1(p1,p2,p3);"的输出
- C++:将控制台输出存储在宏中更好吗
- 创建一个函数以在输入为负数或零时输出字符串.第一次执行用户定义的函数
- 如何在OMNET++中指定与命令行参数组合的输出文件名
- 为什么我的代码在输出中增加了93天
- 如何从void函数输出字符串
- 输入到文件并输出到另一个文件,并将流文件传递给函数
- AES加密到解密未正确输出
- 如何将c++程序的一些输出传递给shell,以便在shell中使用
- 使用C++程序合并排序没有得到正确的输出
- 为什么我不能在不创建字符串变量的情况下使用函数的字符串输出
- C++格式化输出问题
- 将值从二维数组输出到文本文件
- 集合上的输出迭代器:assign和increment迭代器
- 在while循环中输入带有std::cin的字符串后,控制台会输出大量胡言乱语
- 为什么rk4.do_step不输出C++中的初始条件
- 输出没有重复元素的动态数组(收缩数组)C++
- 在 c++ 中使用 cout.precision() 的奇怪输出