c++如何控制输出浮点数小数点后若干位

 更新时间:2023年09月09日 17:08:20   作者:songlu2333  
这篇文章主要介绍了c++如何控制输出浮点数小数点后若干位问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教

C++输出实现保留小数点后若干位

此方法主要参见《c++primer中文版》第五版670页的内容,使用<iomanip>标准库中的fixed操纵符与setprecision操纵符。

setprecision操纵符

setprecision操纵符可以指定浮点数的打印精度(总的位数),四舍五入且超过原有位数不会补零。

fixed操纵符

fixed操纵符可以改变流的状态以使用定点十进制表示浮点数,默认精度是小数点后6位,不足补零。

除此之外,iomanip中还有其他针对浮点数显示的操作符,例如scientific(科学记数法显示)、hexfloat(16进制显示),defaultfloat(恢复默认状态)。

fixed+setprecision

fixed系列的操作符会改变流的精度的默认含义,默认情况下,精度是指数字的总位数,包括小数部分位数与整数部分位数。

但在使用fixed、scientific、hexfloat后,精度值只控制小数部分,于是我们可以同时使用fixedsetprecision控制小数点后的位数,下图设置小数点后5位输出浮点数。

c++输出浮点数值“保留n位小数”或“保留n位有效位”

我们经常在输出浮点数值时,需要保留3位 / 2位等小数,或者保留几位有效位。这里有一个比较好用的方法。首先需要包含 iomanip 头文件。

1、保留n位小数位

使用fixed 和 setprecision(n)方法,参数n表示保留的小数位个数。

#include <iostream>
#include <iomanip>
using namespace std;
void main()
{
	double PT = 3.14159267;
	//保留三位小数
	cout << fixed <<setprecision(3) << PT <<endl;
	//保留三位有效位
//	cout << setprecision(2) << PT <<endl;
	getchar();
}

结果:

2、保留n位有效位

只使用setprecision(n)方法,参数n表示保留的有效位个数。

#include <iostream>
#include <iomanip>
using namespace std;
void main()
{
	double PT = 3.14159267;
	//保留三位小数
//	cout << fixed <<setprecision(3) << PT <<endl;
	//保留两位有效位
	cout << setprecision(2) << PT <<endl;
	getchar();
}

结果:

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • 浅析C++中的多态与文件操作

    浅析C++中的多态与文件操作

    多态是面向对象编程(OOP)的核心概念之一,它允许对象在相同操作下表现出不同的行为,本文主要为大家介绍了C++中多态与文件操作的相关知识,希望对大家有所帮助
    2024-04-04
  • Qt拖放操作和打印操作的实现

    Qt拖放操作和打印操作的实现

    本文主要介绍了Qt拖放操作和打印操作的实现,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-04-04
  • C++vector自定义大小方式

    C++vector自定义大小方式

    这篇文章主要介绍了C++vector自定义大小方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-05-05
  • 基于C++ OpenCV制作电子相册查看器

    基于C++ OpenCV制作电子相册查看器

    这篇文章主要介绍了如何使用OpenCV C++ 制作电子相册查看器。类似于win10系统的“照片”功能。感兴趣的小伙伴可以跟随小编一起学习一下
    2022-01-01
  • C++中最常用的容器用法与排序实例

    C++中最常用的容器用法与排序实例

    C++ 中容器被定义为:在数据存储上,有一种对象类型,它可以持有其它对象或指向其它对像的指针,这种对象类型就叫做容器,这篇文章主要给大家介绍了关于C++中最常用的容器用法与排序的相关资料,需要的朋友可以参考下
    2021-08-08
  • 详解C++中单继承与多继承的使用

    详解C++中单继承与多继承的使用

    C++的继承机制相对其他语言是比较复杂的一种,不同于java只支持单继承,C++不仅支持单继承,也支持多继承。本文将详细讲解C++中单继承与多继承的使用,需要的可以参考一下
    2022-04-04
  • C++利用opencv实现人脸检测

    C++利用opencv实现人脸检测

    这篇文章主要为大家详细介绍了C++利用opencv实现人脸检测,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-01-01
  • C++实现Armadillo库与OpenCV库之间的数据格式转换

    C++实现Armadillo库与OpenCV库之间的数据格式转换

    在C++领域,数据格式转换是常见且关键的任务,尤其是在使用多个不同的库进行复杂的数据处理时,Armadillo和OpenCV是两个在科学计算和计算机视觉领域非常受欢迎的库,下面我们将详细探讨如何在C++中实现Armadillo库与OpenCV库之间的数据格式转换,需要的朋友可以参考下
    2025-03-03
  • QT圆形图像剪切功能实现

    QT圆形图像剪切功能实现

    这篇文章主要介绍了QT圆形图像剪切,实现代码包括剪切代码,完整QML源码,C++代码,代码简单易懂,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-10-10
  • Matlab利用遗传算法GA求解非连续函数问题详解

    Matlab利用遗传算法GA求解非连续函数问题详解

    遗传算法起源于对生物系统所进行的计算机模拟研究。其本质是一种高效、并行、全局搜索的方法,能在搜索过程中自动获取和积累有关搜索空间的知识,并自适应地控制搜索过程以求得最佳解。本文将利用其求解非连续函数问题,需要的可以参考一下
    2022-09-09

最新评论