cout.precision()该怎么用?

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了cout.precision()该怎么用?相关的知识,希望对你有一定的参考价值。

我编了一个这样的程序,可是结果只输出8,为什么呀?cout.precision()应该怎样用呢?
#include<iostream>
#include<iomanip>
using namespace std;
int main()

double a=25/3;
cout.precision(6);
cout <<a <<endl;
return 0;

这是C和C++语言的毛病。
double a;
a = 25/3;
尽管a是double,按理论 右式应当 向高级变量类型 转化后再运算,可是,C和C++把它处理成 整数除以整数,并按 整除处理。结果
25/3 等于整数 8。

为避免C和C++语言的这种毛病,书写表达式时,自己要注意类型转换,或书写常数时要注意加上小数点:
double a=25.0 / 3.0;
或 double a=25. / 3;

cout.precision(6); 输出小数点后5位,第6位四舍五入。
参考技术A 这个cout.precision()函数的返回值就是设定前的有效位数,你的前面就是4,默认为6,这个位数大多数时候不会用得到,
因此一般而言最好是单独使用一个语句
你后面接着再加上一句:
std::cout
<<
std::cout.precision(5)<<
std::endl;
看看输出结果是什么
参考技术B cout.precision(6); 输出6位有效数字,第6位四舍五入得到(前提为原数据有足够的位数) 参考技术C 给你一个例子 用6.0运行 参考下
//C++ precision() C++四舍五入 函数设置或返回当前要被显示的浮点变量的位数
//streamsize precision();
//streamsize precision( streamsize p );

#include<iostream.h>

void main()

float num = 314.15926535;
cout.precision(4);
cout << num<<endl;

cout.precision(5);
cout << num<<endl;

cout.precision(6);
cout << num<<endl;
参考技术D 改下
double a=25.0/3;
如果像你那样写的话25/3是整数间的运算得8.
还有如果是小数点后8位的话要用
cout<<fixed<<a<<endl;

以上是关于cout.precision()该怎么用?的主要内容,如果未能解决你的问题,请参考以下文章

c++,怎么控制输出格式,使每一行格式相同,且对齐,就比如输出一个表格形式

cout对象一些常用方法的总结

cout 输出固定位数的有效数字

round()round函数返回啥值?

为啥c++cout语句整数相除保留了五位小数?

c++:cout