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; }
以上为个人经验,希望能给大家一个参考,也希望大家多多支持我们。
精彩评论