以指定格式打印值的 C++ 程序
假设我们有三个双精度值。我们必须格式化它们并按以下格式打印它们。
我们必须用小写字母以十六进制格式打印第一个值的整数部分。
我们必须将第二个值打印到小数点后两位,在它前面放一个符号来显示它是正数还是负数。要打印的第二个值必须右对齐,长度为15个字符,在左侧未使用的位置用下划线填充。
我们必须以科学记数法打印最多九位小数的第三个值。
所以,如果输入像256.367,5783.489,12.5643295643,那么输出将是
0x100 _______+5783.49 1.256432956E+01
为了解决这个问题,我们将按照以下步骤操作-
hex标志以十六进制格式打印值,showbase标志显示十六进制值的“0x”前缀,左侧标志将值填充到输出字段,并在值的右侧插入填充字符,nouppercase标志打印输出全部小写。
右侧标志通过在值左侧插入填充字符将值填充到输出字段,固定标志以定点表示法打印值,set(15)将输出字段长度设置为15,showpos标志在输出前插入一个'+'符号,setfill('_')用下划线填充输出,并将setprecision()值的精度设置为小数点后2位。
setprecision()将值的精度设置为小数点后9位,科学标志以科学记数法打印值,大写使输出值全部为大写字母,noshowpos省略输出值前的任何正号。
让我们看看以下实现以获得更好的理解-
#include <iostream>
#include <iomanip>
using namespace std;
void solve(double a, double b, double c) {
cout << hex << showbase << nouppercase << left << (long long) a << endl;
cout << right << fixed << setw(15) << setfill('_') << setprecision(2) << showpos << b << endl;
cout << setprecision(9) << scientific << uppercase << noshowpos << c << endl;
}
int main() {
solve(256.367, 5783.489, 12.5643295643);
return 0;
}输入
256.367, 5783.489, 12.5643295643输出结果
0x100 _______+5783.49 1.256432956E+01
热门推荐
10 八一幼儿祝福语大全简短
11 公司乔迁食堂祝福语简短
12 婚礼结束聚餐祝福语简短
13 儿媳买车妈妈祝福语简短
14 毕业送礼老师祝福语简短
15 同事辞职正常祝福语简短
16 恭贺新婚文案祝福语简短
17 金店立秋祝福语简短英文
18 婆婆高寿祝福语大全简短