最近在写一个模拟的裁判评分程序,涉及到分数的精度和输出格式问题,特总结如下:
代码背景:
#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;