c++保留到小数点后n位_保留n位有效数字

保留到小数点后n位的四种方法

#include ★★★★★

#include 
#include 

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;
}

结果自动的进行了四舍五入

分别详细讲解上面的四种方法,包括它们的原理、异同以及推荐使用的情况。

  1. 第一种方法:
  • 原理:使用fixedsetprecision(3)来设置输出格式,其中fixed确保使用固定点表示法,而setprecision(3)设置小数点后位数为3位。
  • 异同:这种方法与其他两 种方法的主要区别在于它是通过设置流的状态来控制输出格式的。
  • 推荐使用的情况:当需要确保输出格式的一致性时,可以使用这种方法。
  1. 第二种方法:
  • 原理:使用setf()函数设置输出格式为固定点表示法,然后使用setprecision(3)设置小数点后位数为3位。
  • 异同:这种方法与第一种方法的原理相似,但它是通过调用函数来设置输出格式的。
  • 推荐使用的情况:当需要更明确地控制输出格式时,可以使用这种方法。
  1. 第三种方法:
  • 原理:使用setiosflags()函数来设置输出格式为固定点表示法,然后使用setprecision(3)设置小数点后位数为3位。
  • 异同:这种方法与前两种方法的原理相似,但它是通过设置标志位来控制输出格式的。
  • 推荐使用的情况:当需要更灵活地控制输出格式时,可以使用这种方法。

综上所述,为了确保输出的一致性和准确性,推荐使用第一种或第二种方法,因为它们明确指定了固定点表示法和精度,能够更好地控制输出的格式。

精确到 n 位有效数字

#include
#include 
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;
}

你可能感兴趣的:(C++知识点,c++,算法,开发语言)