关于C++的cout输出小数的精度控制

​​​​​​​

 

最近在写一个模拟的裁判评分程序,涉及到分数的精度和输出格式问题,特总结如下:

代码背景:

#include <iostream>

using namespace std;
float num = 1.25;

1、设置对齐方式(如:右对齐,ios::right):

cout.setf(ios::right); // 设置对齐方式
cout << num << endl;;

效果(不明显,当数字长度小于输出宽度的时候才能看出效果,如2所示):


 

2、将数字输出宽度设置为8:

cout.setf(ios::right); // 设置对齐方式
cout.width(8); //设置输出宽度

cout << num << endl;

效果:

3、将宽度多余的部分用某个字符(如:'0')填充:

cout.setf(ios::right); // 设置对齐方式
cout.width(8); //设置输出宽度
cout.fill('0'); //将多余的空格用0填充
	
cout << num << endl;

效果:

4、设置精度:保留**位有效数字,如果小数点最后面有0,则自动去掉:

float num = 1.25;

cout.setf(ios::right); // 设置对齐方式
cout.width(8); //设置输出宽度
cout.fill('0'); //将多余的空格用0填充

cout.precision(2); //设置输出精度,保留有效数字
	
cout << num << endl;


效果:

5.保留小数点后有效的位数。如:1.25 保留4位有效数字后的1.250中0的显示,要依靠cout.setf(ios::showpoint)函数(因为保留有效数字的函数不会保留没用的0有效位):

cout.setf(ios::right); // 设置对齐方式
cout.width(8); //设置输出宽度
cout.fill('0'); //将多余的空格用0填充
cout.setf(ios::showpoint); //将小数精度后面的0显示出来
cout.precision(4); //设置输出精度,保留有效数字
	
cout << num << endl;


效果:

6、保留小数点后**位数

cout.setf(ios::right); // 设置对齐方式
cout.width(8); //设置输出宽度
cout.fill('0'); //将多余的空格用0填充

cout.flags(ios::fixed);
cout.precision(4); //设置输出精度,
	
cout << num << endl;


效果(保留4为小数):


 

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值