#include ★★★★★
#include <iostream>
#include <iomanip>
using namespace std;
int main() {
double num = 1.23456789;//保留小数点后三位-->1.234
cout << "一:";
cout << fixed << setprecision(3) << num << endl; //保留小数点后三位-->1.234
cout << "二:";
cout.setf(ios::fixed);
cout << setprecision(3) << num << endl;
cout << "三:";
cout << setiosflags(ios::fixed) << setprecision(3) << num << endl;
return 0;
}
结果自动的进行了四舍五入
分别详细讲解上面的四种方法,包括它们的原理、异同以及推荐使用的情况。
fixed
和setprecision(3)
来设置输出格式,其中fixed
确保使用固定点表示法,而setprecision(3)
设置小数点后位数为3位。setf()
函数设置输出格式为固定点表示法,然后使用setprecision(3)
设置小数点后位数为3位。setiosflags()
函数来设置输出格式为固定点表示法,然后使用setprecision(3)
设置小数点后位数为3位。综上所述,为了确保输出的一致性和准确性,推荐使用第一种或第二种方法,因为它们明确指定了固定点表示法和精度,能够更好地控制输出的格式。
#include<iomanip>
#include <iostream>
using namespace std;
int main()
{
double num = 1.23456789;
cout << "原数:" << num << endl;
cout << "保留两位有效数字:" << endl;
cout << setprecision(2) << num << endl;
cout << "保留三位有效数字:" << endl;
cout << setprecision(3) << num << endl;
cout << "保留四位有效数字:" << endl;
cout << setprecision(4) << num << endl;
cout << "保留十位有效数字:" << endl;
cout << setprecision(10) << num << endl;
system("pause");
return 0;
}