首页 > 后端开发 > C++ > 正文

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

王林
发布: 2023-09-03 12:33:08
转载
976 人浏览过

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

假设我们有三个双精度值。我们需要按照以下格式对它们进行格式化和打印。

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

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

  • 我们需要以科学计数法打印第三个值,保留九位小数。

因此,如果输入为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(&#39;_&#39;) << 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
登录后复制
登录后复制

以上是C++程序以指定格式打印值的详细内容。更多信息请关注PHP中文网其他相关文章!

相关标签:
来源:tutorialspoint.com
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板