
假设我们有三个双精度值。我们需要按照以下格式对它们进行格式化和打印。
因此,如果输入为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位小数,scientific标志以科学计数法打印值,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 &l
.........................................................