C++ 保留小数的用法

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

  

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

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

 

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

C++ 保留小数的用法_第1张图片

 

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

cout<

 

 

#include 

解释头文件 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<

输出:

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

 

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

(比如 cout<

 


2、上述函数的详细说明

 

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

如  cout<

结果是:

(空格)(空格)255

 

(2)

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

如  cout<

结果是:

@@255

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

cout<

的运行结果为 ***123456,这里setfill('*')<

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

 

(3)

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

如 cout<

cout<

cout<

结果是:

(空格)(空格)317

(空格)(空格) 255

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

 

(4)

setprecision用法

①、

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

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

1

2

float  a = 123.666;

cout<

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

 

②、

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

float a = 123.666;

cout<

将输出 1.2e+002。

 

③、

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

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

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

例如:

//  四舍六入五成双

cout<

输出:

C++ 保留小数的用法_第2张图片

 

 

扩展用法:

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)     强制显示符号

 

你可能感兴趣的:(ACM,----,知识点,C++)