我有一个 C++ 程序,它接收值并像这样打印出值:
getline(in,number);
cout << setw(10) << number << endl;
我有一个等效的 C 程序,它接收值并像这样打印出来:
fscanf(rhs, "%e", &number);
printf("%lf\n", number);
但是当 C++ 程序打印出 0.30951
时,C 程序打印出 0.309510
。更多示例:C++:0.0956439
C:0.095644
。只要值是 7 位长,它似乎打印相同的结果,但如果它比 7 位短,它会在末尾添加一个额外的 0。如果它的长度超过 7 位,则向下舍入为 6 位。我希望 C 结果与 C++ 程序匹配。任何帮助将不胜感激。
谢谢。
注意:数字是一个 float ,数字是从文件中读取的。
最佳答案
利用 C 格式打印语句中的长度和精度说明符:
printf( "%6.4lf", number );
在六个字符宽的“单元格”中打印四位小数。
您可以对长度或精度使用通配符以在运行时提供该值:
int precision = 4;
printf( "%6.*lf", precision, number );
关于c++ - C - 打印浮点值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15511276/