C++中利用cout和fstream采用非科学计数法输出

软件发布|下载排行|最新软件

当前位置:首页IT学院IT技术

C++中利用cout和fstream采用非科学计数法输出

冷面杰拉德   2022-11-12 我要评论

C++ cout和fstream采用非科学计数法输出

1.cout非科学计数法输出

cout.setf(ios::fixed);
cout.precision(3); // 精度为输出小数点后3位

2.fstream文件流非科学计数法输出

double test=3.1415926;
ofstream file(fileName);
file.setf(ios::fixed);
file.precision(5);//精度为输出小数点后5位
file<<test;
file.close();

3.fstream中几个函数

 file.precision(8);        
 file.flags(ios::left|ios::fixed);
 file.fill('0' );
 file.width(14);

前三个函数是一次设定始终有效,而第四个2只对下一次输入有效。依次解释这四个函数的意义:

  • file.precision(3); 设定精度,小数点后有效数的位数,若输出0.32456,结果为0.324,;若输出0.3,结果为0.3。也就是对缺少的位数该函数不会去补充;
  • file.fill(‘0’ );该函数的作用就是把空出来的位数用某一字符来补充。但注意仅设置precision的情况下是不会补充的。因为precision只负责精度,而不会限定具体位数。
  • file.width(14);则是限定输出的位数。但在系统优先满足精度,输出位数可能无法保证。例如321.45678,若设定8位宽度,5位精度,最终结果是321.45678。即优先满足精度要求,其次满足宽度要求。
  • 同样上例中若精度为2位,结果为321.45.剩下的可以用fill来补充

但设定以上三种条件也无法得出满意的结果。

因为系统默认数字右对齐,也就是填充字符会填充在数字的左边!

此时必须进步设定file.flags(ios::left|ios::fixed);其中ios::left是令字符左对齐,而ios::fixed,该参数指定的动作是以带小数点的形式表示浮点数,并且在允许的精度范围内尽可能的把数字移向小数点右侧;

C++ 输出不使用科学计数法

#include <iostream>
#include <iomanip>
using namespace std;
int main()
{
    //强制使用小数,防止使用科学计数法
    cout << fixed;
    //控制显示的精度,控制小数点后面的位数。而整数太大时也会使用科学计数法,要输出完整的整数时就可以将下面改成setprecision(0)
    cout << setprecision(7);
    double DoubleNum = 100.0 / 3.0;
    cout << DoubleNum * 10000 << endl;
    cin.get();
    return 0;
}

以上为个人经验,希望能给大家一个参考,也希望大家多多支持。

Copyright 2022 版权所有 软件发布 访问手机版

声明:所有软件和文章来自软件开发商或者作者 如有异议 请与本站联系 联系我们