开发者

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

目录编程
  • C++ cout和fstream采用非科学python计数法输出
  • C++ 输出不使用科学计数法

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);    
fiphple.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;
   ja开发者_开发培训vascript //控制显示的精度,控制小数点后面的位数。而整数太大时也会使用科学计数法,要输出完整的整数时就可以将下面改成setprecision(0)
    cout << setprecision(7);
    double DjsoubleNum = 100.0 / 3.0;
    cout << DoubleNum * 10000 << endl;
    cin.get();
    return 0;
}

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

0

上一篇:

下一篇:

精彩评论

暂无评论...
验证码 换一张
取 消

最新开发

开发排行榜