首先要加头文件:iomanip

一:setprecision

作用:控制输出流显示浮点数的数字个数,setprecision(n)就是输出的n个数,会有四舍五入。

  比如:double s=20.7843000,

    cout<<setprecision(1)<<s<<endl;会输出2e+001,因为要输出一个数字,所以只有2.

    cout<<setprecision(2)<<s<<endl;会输出21。

    cout<<setprecision(3)<<s<<endl;会输出20.8。

    cout<<setprecision(6)<<s<<endl;会输出20.7843。

    cout<<setprecision(7)<<s<<endl;会输出20.7843。

    cout<<setprecision(8)<<s<<endl;会输出20.7843。

  可见,小数部分末尾为0时,是输不出来的!

  要想输出来,就得用showpoint了。

特别提示 :

(如果再在这些语句后面加个两个语句:

  cout<<1<<endl;

  cout<<1.00800<<endl;

  猜到会输出什么吗?

  第一条输出:1。不是浮点型。

  第二条为:1.008。承接setprecision(8)的这条规则语句。

  注:

  如果直接有语句

  int main()

  {

    cout<<1<<endl;

    cout<<1.00<<endl;

  }

  第一条输出:1。

  第二条也为:1。按整型输出 

二:setprecision与showpoint

  语法:在输出语句前声明:cout.setf(ios::showpoint);就行了!

  还比如:double s=20.7843000,

    cout.setf(ios::showpoint);

    cout<<setprecision(1)<<s<<endl;就会输出2.e+001,注意,2和e之间多了一个“.”。

    cout<<setprecision(2)<<s<<endl;会输出21.。多个点!

    cout<<setprecision(3)<<s<<endl;会输出20.8。

    cout<<setprecision(6)<<s<<endl;会输出20.7843。

    cout<<setprecision(7)<<s<<endl;会输出20.78430。

    cout<<setprecision(8)<<s<<endl;会输出20.784300。

  可见,就会输出想要的数据数目!

特别提示 :

(如果再在这些语句后面加个两个语句:

    cout<<1<<endl;

    cout<<1.0080<<endl;

  猜到会输出什么吗?

    第一条输出:1。不是浮点型。

    第二条也为:1.0080000。承接setprecision(8)的这条规则语句。

三:setprecision与fixed

  如果想要保留几位小数,那setprecision就得与fixed合作了!!

  语法:在输出语句前声明:cout.setf(ios::fixed);

  比如:double s=20.7843909

    cout.setf(ios::fixed);

    cout<<setprecision(1)<<s<<endl;就会输出2.8  。

    cout<<setprecision(2)<<s<<endl;会输出21.78。多个点!

    cout<<setprecision(3)<<s<<endl;会输出20.784。

    cout<<setprecision(6)<<s<<endl;会输出20.784391。

    cout<<setprecision(7)<<s<<endl;会输出20.7843909。

    cout<<setprecision(8)<<s<<endl;会输出20.78439090。

特别提示 :

(如果也再在这些语句后面加个两个语句:

    cout<<1<<endl;

    cout<<1.008<<endl;

  猜到会输出什么吗?

  第一条输出:1。

  第二条为:1.00800000。

  就是承接了setprecision(8)的这条规则语句,是浮点型的都会保留8个小数。是整型的还是整型!)

  语句也可以写成:cout<<fixed<<setprecision(2)<<s<<endl;

就算后面的语句没有写<<fixed,同样会按有<<fixed处理。

比如有语句:

  cout<<fixed<<setprecision(2)<<s<<endl;

  A:cout<<setprecision(7)<<s<<endl;

  B:cout<<setprecision(8)<<s<<endl;

  AB语句均会按保留7个,8个小数处理,不会再按有7或8个浮点数处理。

如果下面有语句c:

  cout<<1.008<<endl;也会保留8个小数。

四:setprecision、showpoint与fixed

  {

    cout<<fixed<<setprecision(2)<<123.456<<endl;//输出的结果是123.46 
    cout<<showpoint<<12345.0006666<<endl;//输出12345.0 
    cout<<fixed<<setprecision(2)<<123.456<<endl;

  }

比如:double s=20.7843909

1.有语句

  cout<<setprecision(2)<<s<<endl;//输出21

  cout<<fixed<<s<<endl;//输出20.78

2.有语句:

  cout<<setprecision(2)<<s<<endl;//输出21

  cout<<showpoint<<s<<endl;//输出21.(有个点)

3.有语句:

  cout<<fixed<<s<<endl;//输出20.78391 
  cout<<showpoint<<s<<endl;//输出20.78391 
4.有语句:

  cout<<setprecision(2)<<s<<endl;//输出21 
  cout<<fixed<<s<<endl;//输出20.78 
  cout<<showpoint<<s<<endl;//输出20.78

5.有语句:

  cout<<setprecision(2)<<s<<endl;//输出21 
  cout<<showpoint<<s<<endl;//21.(有个点) 
  cout<<fixed<<s<<endl;//20.78

setprecision、fixed、showpoint的用法总结的更多相关文章

  1. setprecision、fixed、showpoint的用法总结(经典!!超经典!!)

    首先要加头文件:iomanip 一:setprecision 作用:控制输出流显示浮点数的数字个数,setprecision(n)就是输出的n个数,会有四舍五入. 比如:double s=20.784 ...

  2. setprecision、fixed、showpoint的用法总结(经典!!超经典!!)【转】

    本文转载自:http://blog.csdn.net/u011321546/article/details/9293547 首先要加头文件:iomanip 一:setprecision 作用:控制输出 ...

  3. css中table-layout:fixed 属性的用法

    table-layout:fixed 属性的用法:如果想要一个table固定大小,里面的文字强制换行(尤其是在一长串英文文本,并且中间无空格分隔的情况下),以达到使过长的文字 不撑破表格的目的,一般是 ...

  4. setprecision **fixed

    #include <iostream> #include <iomanip> using namespace std; int main( void ) { const dou ...

  5. C / C++ 保留小数函数(setprecision(n)的一些用法总结)

    从C语言开始正式学习C++,但是一上来输出位数就懵了,查资料才知道C++需要使用 “ setprecision  ”函数.自己总结一下. 首先说C++代码 #include <iomanip&g ...

  6. CSS中position:fixed的相关用法

    CSS中的三大重点知识: 1.float,浮动 2.盒子模型 3.position绝对定位 今天主要写下position中fixed相关知识: position:static,relative,abs ...

  7. STL之sstream的用法

    STL之sstream的用法 说在前面: 库定义了三种类:istringstream.ostringstream和stringstream,分别用来进行流的输入.输出和输入输出操作.另外,每个类都有一 ...

  8. poj3122-Pie(二分法+贪心思想)

    一,题意: 有f+1个人(包括自己),n块披萨pie,给你每块pie的半径,要你公平的把尽可能多的pie分给每一个人 而且每个人得到的pie来自一个pie,不能拼凑,多余的边角丢掉.二,思路: 1,输 ...

  9. C++编程学习(九)this指针&友元函数

    mooc西工大魏英老师的课程通道关闭了,难受.现在边看工程代码边重温刷第一遍C++时候的知识点,顺序没有按照大纲的来,想到哪写到哪. this是干啥用的? 简介:在 C++ 中,每一个对象都能通过 t ...

随机推荐

  1. php 批量删除

    <body><form action="shanchu.php" method="post"><table width=" ...

  2. Hamilton四元数群的表示

    Hamilton四元数群$Q_8=\mathbb H=\{\pm e,\pm i,\pm j,\pm k\}$满足如下运算法则: $e$为单位元且同号得正.异号得负,此外$e=i^2=j^2=k^2, ...

  3. haproxy+keepalived

    global_defs { router_id LVS_DEVEL } vrrp_script chk_haproxy { script "killall -0 haproxy" ...

  4. 统计java中字符串,数组,集合大小(长度)

    字符串长度用String.length(); 数组用String[].length; 集合用collection.size();

  5. Linux下安装Tomcat服务器和部署Web应用

    一.上传Tomcat服务器

  6. Service and controller in angularJs

    Separation of concern is at the heart while designing an AngularJS application. Your controller must ...

  7. 正定矩阵(positive definite matrix)

    设M是n阶方阵,如果对任何非零向量z,都有zTMz> 0,其中zT 表示z的转置,就称M正定矩阵. 正定矩阵在合同变换下可化为标准型, 即对角矩阵. 所有特征值大于零的对称矩阵也是正定矩阵.   ...

  8. git使用

    1.权限校验 首先,您的数据保存在远端服务器一份,服务器需要对您的身份进行识别,一段RAS加密字串, 启动GUI,step1:创建秘钥,generate SSHkey. step2:添加密钥:去你的代 ...

  9. 恶心的content

    getBaseContent getApplicationContent ...

  10. SPOJ DISUBSTR ——后缀数组

    [题目分析] 后缀数组模板题. 由于height数组存在RMQ的性质. 那么对于一个后缀,与前面相同的串总共有h[i]+sa[i]个.然后求和即可. [代码](模板来自Claris,这个板子太漂亮了) ...