Chinaunix首页 | 论坛 | 博客
  • 博客访问: 988516
  • 博文数量: 158
  • 博客积分: 4380
  • 博客等级: 上校
  • 技术积分: 2367
  • 用 户 组: 普通用户
  • 注册时间: 2006-09-21 10:45
文章分类

全部博文(158)

文章存档

2012年(158)

我的朋友

分类: C/C++

2012-11-23 15:08:18

按有效位输出是 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;
}

阅读(928) | 评论(1) | 转发(1) |
给主人留下些什么吧!~~

网友评论2012-11-23 15:08:50

疯猫
存档备查