C++保留小数位数问题

本文链接:https://blog.csdn.net/Eclipse_hao/article/details/83653492


 

setprecision() 和 setiosflags() 

这两个函数是头文件#include<iomanip>里的函数,记得加头文件#include<iomanip>

setprecision()

顾名思义:就是设定精度。用来控制输出的数的位数(从左到右的),自动四舍五入。且不保留小数后的0。比如:

int pi = 3.1415926000;

cout<<setprecision(1)<<pi<<endl;

>>> 3

cout<<setprecision(2)<<pi<<endl;

>>> 3.1

cout<<setprecision(5)<<pi<<endl;

>>> 3.1416

(四舍五入)

cout<<setprecision(10)<<pi<<endl;

>>> 3.1415926

(末尾不保留0)

我们可以使用这个函数初步控制小数位数。但是呢

如果整数部分不确定,或者要求末尾保留0的时候,那我们就无法准确保留适当的小数位数,因此我们需要另一个函数:

setiosflags()

这是一个格式控制函数,它有很多参数,可以实现不同的输出操作,详见:https://blog.csdn.net/qq_40688707/article/details/79502225

我们在这里主要用到其中两个:fixed 和 showpoint。

首先说fixed,以定点方式显示实数,即显示整数部分。举个栗子:

int pi = 3.1415926000;

cout<<setiosflags(ios::fixed)<<setprecision(2)<<pi<<endl;

>>> 3.14

cout<<setiosflags(ios::fixed)<<setprecision(4)<<pi<<endl;

>>> 3.1416

可见此时setprecision()已经是只控制小数位数了,但是:

cout<<setiosflags(ios::fixed)<<setprecision(10)<<pi<<endl;

>>> 3.1415926

它仍然不能保留0。这时就有了showpoint

还是那个例子:

cout<<setiosflags(ios::fixed|ios::showpoint)<<setprecision(10)<<pi<<endl;

>>> 3.1415926000

这样我们就能完全控制小数位数的输出了。


————————————————
版权声明:本文为CSDN博主「Wander_Hero」的原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/Eclipse_hao/article/details/83653492

posted @ 2019-09-09 18:54  CodingNote  阅读(172)  评论(0)    收藏  举报