在C语言中,我们学过 Printf 输出格式 来控制输出几位小数
printf("%.7ld\n",ans); // 四舍五入
在 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<
输出:
当输出长度大于等于 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 将输出123.67(注意这里,它会四舍五入,不是从小数点之后五位,而是有效位数) ②、 如果 setprecision(n) 里的参数 n 小于整数位数,将以指数形式输出,例如 将输出 1.2e+002。 ③、 setiosflags(ios::fixed) 是用定点方式表示实数 如果 setprecision(n) 与 setiosflags(ios::fixed) 合用,就表示保留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) 强制显示符号
float
a = 123.666;
cout<
float
a = 123.666;
cout<
// 四舍六入五成双
cout<