cout输出控制——位数和精度控制

本文介绍了在 C++ 中如何使用 fixed 和 setprecision 函数精确控制浮点数的输出位数,并解决了连续输出时格式相互影响的问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

刷到一道需要控制输出精度和位数的题目

刚开始以为单纯使用 iomanip 函数库里的 setprecision 就可以,但 OJ 给我判了答案错误,后来一想这样输出并不能限制位数只能限制有效位数。

比如说 0.000101000110

用 setprecision(4) 答案是 0.000101 这里甚至把最后一位的有效数字 0 省略了!!

后来了解到 fixed 关键字

那么在这里若要控制小数点后 N 位 只要写成 

cout << fixed << setprecision(N) 

即可达到效果。

 

然而却有了下面的问题。。。

cout << fixed << setprecision(4) << 0.000101000110 << endl;
cout << 3.141593 <<endl;

却得到了这样的输出结果

0.0001
3.1416

没错,之后的输出被同样的输出格式所限制了。

那就要找到办法清除输出控制

遗憾的是 CPP 目前并没有办法消除 setprecision 标签的效果方法,

但是消除 fixed 还是有的

在不需要 fixed 效果输出的前一行加上

cout.unsetf( ios::fixed );

例如

cout << fixed << setprecision(4) << 0.000101000110 << endl;
cout.unsetf( ios::fixed );
cout << 3.141593 <<endl;

输出结果如下:

0.0001
3.142

但可以通过再次设定 setprecision 标签来达到控制位数

例如

cout << fixed << setprecision(4) << 0.000101000110 << endl;
cout.unsetf( ios::fixed );
cout <<setprecision(6) << 3.141593 <<endl;

输出结果如下:

0.0001
3.14159

 

所以在碰到对精确度和位数都有要求的题目时需要格外注意 setprecision 标签的设置状态!

 

参考链接:cplusplus.com/reference/ios/fixed

转载于:https://www.cnblogs.com/4770k/p/6103011.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值