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;
}
以上为个人经验,希望能给大家一个参考,也希望大家多多支持编程网。