Chinaunix首页 | 论坛 | 博客
  • 博客访问: 240325
  • 博文数量: 127
  • 博客积分: 34
  • 博客等级: 民兵
  • 技术积分: 655
  • 用 户 组: 普通用户
  • 注册时间: 2012-10-03 10:53
文章分类

全部博文(127)

文章存档

2013年(19)

2012年(108)

分类:

2012-12-01 15:04:03

按有效位输出是 setprecision,按小数位数输出也是setprecision,但到底是谁取决于fixed。
cout << 非fixed << setprecision(n) << float-point-number; 是按n位有效数输出
cout << fixed << setprecision(n) << float-point-number; 是按n位小数输出

测试代码:
#include
#include
using namespace std;


int main( void )
{
    const double value = 12.3456789;


    cout << value << endl; // 默认以6精度,所以输出为 12.3457
    cout << setprecision(4) << value << endl; // 改成4精度,所以输出为12.35
    cout << setprecision(8) << value << endl; // 改成8精度,所以输出为12.345679
    cout << fixed << setprecision(4) << value << endl; // 加了fixed意味着是固定点方式显示,所以这里的精度指的是小数位,输出为12.3457
    cout << value << endl; // fixed和setprecision的作用还在,依然显示12.3457
    cout.unsetf( ios::fixed ); // 去掉了fixed,所以精度恢复成整个数值的有效位数,显示为12.35
    cout << value << endl;
    cout.precision( 6 ); // 恢复成原来的样子,输出为12.3457
    cout << value << endl;
}

阅读(513) | 评论(0) | 转发(0) |
0

上一篇:C++ 类的静态成员

下一篇:寻找第K大的数

给主人留下些什么吧!~~