C++ 保留小数的用法

在C语言中,我们学过 Printf 输出格式 来控制输出几位小数

  

printf("%.7ld\n",ans);  // 四舍五入

在 C++ 中,学习另外的方法

 

1、首先 满足四舍六入五成双 的法则

 

那为什么我用CB测试出来的是 奇数舍去;偶数进位呢?????

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

 

 

#include <iomanip>

解释头文件 iomanip 的作用


主要是对 cin,cout 之类的一些操纵运算子,比如setfill,setw,setbase,setprecision等等。

它是 I/O 流控制头文件,就像C里面的格式化输出一样.以下是一些常见的控制函数的:

dec   置基数为10   相当于"%d"

hex   置基数为16   相当于"%X"

oct   置基数为8    相当于"%o"

setfill( 'c' )        设填充字符为c

setprecision( n )    设显示有效数字为n位

setw( n )           设域宽为n个字符,保证输出宽度为n

setbase(int n) :    将数字转换为 n 进制.

 

例如:

cout << setw(3)<<1<<setw(3)<<10<<setw(3)<<100<< endl;

输出:

   _ _1_10100 (默认是右对齐) ( _ 代表空格)

 

当输出长度大于等于 3 时(<<1000),setw(3)不起作用。

(比如 cout<<setw(3)<<100 输出 100 ;  但 cout<<setw(4)<<100  就会输出 空格100 )

 


2、上述函数的详细说明

 

(1)▲setw(n)用法: 通俗地讲就是预设宽度为n

如  cout<<setw(5)<<255<<endl;

结果是:

(空格)(空格)255

 

(2)

▲setfill(char c) 用法 : 就是在预设宽度中如果已存在没用完的宽度大小,则用设置的字符 c 填充

如  cout<<setfill(‘@‘)<<setw(5)<<255<<endl;

结果是:

@@255

应当指出,setfill和setw只作用于紧随其后的部分,例如

cout<<setfill('*')<<setw(6)<<123<<456;

的运行结果为 ***123456,这里setfill('*')<<setw(6) 只对 123 起作用输出了***123

456作为另一部分随后输出。

 

(3)

▲setbase(int n) : 将数字转换为 n 进制.

如 cout<<setbase(8)<<setw(5)<<255<<endl;

cout<<setbase(10)<<setw(5)<<255<<endl;

cout<<setbase(16)<<setw(5)<<255<<endl;

结果是:

(空格)(空格)317

(空格)(空格) 255

(空格)(空格)(空格) f f

 

(4)

setprecision用法

①、

使用 setprecision(n)   可控制输出流显示浮点数的数字个数。  C++默认的流输出数值有效位是6。

输出格式是数据的有效位数,例如

1

2

float  a = 123.666;

cout<<setprecision(5)<<a;

  将输出123.67(注意这里,它会四舍五入,不是从小数点之后五位,而是有效位数)

 

②、

如果 setprecision(n)  里的参数 n  小于整数位数,将以指数形式输出,例如

float a = 123.666;

cout<<setprecision(2)<<a;

将输出 1.2e+002。

 

③、

setiosflags(ios::fixed)  是用定点方式表示实数

如果 setprecision(n)  与 setiosflags(ios::fixed) 合用,就表示保留n位小数输出。

这里还要注意,每次输出只要设置一次就行了,因为这两个的作用范围是后续对象,而不是仅对后一个对象起作用。

例如:

//  四舍六入五成双

cout<<setiosflags(ios::fixed)<<setprecision(7)<<a<<endl;
  //  保留小数点后7位小数
cout<<setiosflags(ios::fixed)<<setprecision(2)<<b<<endl<<c<<endl;
 //   保留两位小数,参数 n  小于整数位数,将以指数形式输出

输出:

 

 

扩展用法:

setiosflags(ios::fixed)       固定的浮点显示

setiosflags(ios::scientific)     指数表示

setiosflags(ios::left)        左对齐

setiosflags(ios::right)       右对齐 

setiosflags(ios::skipws)      忽略前导空白

setiosflags(ios::uppercase)    16进制数大写输出

setiosflags(ios::lowercase)    16进制小写输出

setiosflags(ios::showpoint)    强制显示小数点

setiosflags(ios::showpos)     强制显示符号

 

  • 3
    点赞
  • 26
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值