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

发布时间:2024年01月05日

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

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

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

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

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

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

精确到 n 位有效数字

#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;
}
文章来源:https://blog.csdn.net/2301_82018821/article/details/135291843
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。