C++ 程序以指定格式打印值

c++server side programmingprogramming

假设我们得到了三个 double 值。我们必须对它们进行格式化,并按以下格式打印它们。

  • 我们必须以十六进制格式用小写字母打印第一个值的整数部分。

  • 我们必须打印第二个值,精确到小数点后两位,并在其前面加上一个符号以显示它是正数还是负数。要打印的第二个值必须右对齐,长度为 15 个字符,在左侧未使用的位置用下划线填充。

  • 我们必须以科学计数法打印第三个值,精确到小数点后 9 位。

因此,如果输入为 256.367、5783.489、12.5643295643,则输出将是

0x100
_______+5783.49
1.256432956E+01

为了解决这个问题,我们将遵循以下步骤 −

  • hex 标志以十六进制格式打印值,showbase 标志显示十六进制值的 '0x'前缀,left 标志通过在值的右侧插入填充字符将值填充到输出字段,nouppercase 标志以全部小写字母打印输出。

  • right 标志通过在值的左侧插入填充字符将值填充到输出字段,fixed 标志以定点表示法打印值,set(15)将输出字段长度设置为 15,showpos 标志插入 '+'输出前带符号,setfill('_') 用下划线填充输出,setprecision() 将值的精度设置为最多 2 位小数。

  • setprecision() 将值的精度设置为最多 9 位小数,科学标记以科学计数法打印值,uppercase 使输出值全部大写,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

相关文章