当你在C++中需要输出小数时,你可以使用C++中的流操作符(<<)结合cout对象进行输出。在输出小数时,需要注意输出的小数位数和小数点的位置,下面是一些实现小数输出的方法:
控制小数位数
#include <iostream>
#include <iomanip>
using namespace std;
int main()
{
double num = 314.15926;
cout << fixed << setprecision(5) << num << endl; // 输出 314.15926
return 0;
}
上述是通过控制小数位数来实现小数输出的,下面是对fixed和setprecision的分别详解。
#include <iomanip>是C++的输入输出控制头文件(iomanip的全名是input/output manipulation),它提供了一些用于输入输出格式控制的操作符或函数。fixed就是一个定义在<iomanip>种的流操作符,它可以指定浮点数以小数的形式输出,在这里说明以下浮点数有小数和指数(科学计数法)两种表示形式,如果使用了fixed则默认以小数形式输出,如果你想要用科学计数法方式输出则是scientific。
#include <iostream>
#include <iomanip>
using namespace std;
int main()
{
double num = 3.1415926;
cout << fixed << num << endl; // 输出 3.141593
cout << scientific << num << endl; // 输出3.141593e+00
return 0;
}
可以看到使用fixed流操作符时以小数形式输出,使用scientific流操作符时以为科学计数法形式输出。同时fixed和scientific都是保留默认小数点后6位有效数字(会发生进位现象),譬如num原本为3.1415926,而第一个输出的3.141593就是保留了小数点后6位且第六位2进位成了3。所以从这里可以总结出fixed的作用是指定浮点数以小数的形式输出,并保留小数点后六位并允许进位,scientific同上。
`std::setprecision()` 是 C++ 标准库 `<iomanip>` 中的一个函数,该函数用于设置浮点数的输出精度。它的原型如下:
std::streamsize setprecision(std::streamsize n);
该函数接受一个整型参数 `n`,指定浮点数输出的有效数字的总位数(即小数点前面的位数加上小数点后面的位数的总位数)。
例如,如果我们要输出一个浮点数,有效位数设定为 4
double x = 3.1415926;
cout << setprecision(4) << x << endl;
该代码会输出 `3.142`。
现在我们可以知道为什么fixed和setprecision组合可以控制小数位数的输出了,fixed默认保留小数点后六位,setprecison可以控制输出时的有效位数,所以它们组合起来就是setprecison控制fixed保留小数点后的多少位数字。
使用printf函数
使用printf函数可以灵活地控制输出格式。使用printf函数输出小数时,可以使用%.nf来控制小数点后的位数,其中n为小数点后保留的位数。例如,如果要输出3位小数,则可以使用以下语句:
#include <cstdio>
using namespace std;
int main()
{
double num = 3.14159;
printf("%.3f\n", num); // 输出 3.142
return 0;
}
上述代码中,使用%.3f控制输出小数点后的位数为3,结果输出了3.142
————————————————
版权声明:本文为CSDN博主「m0_70809306」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/m0_70809306/article/details/130473356