c语言小数运算setprecision,c++ setprecision用法详解

浮点值可以四舍五入到若干位有效数或精度,这是出现在小数点前后的总位数。可以通过使用setprecision 操作符来控制显示浮点数值的有效数的数量。

下面的程序显示了用不同数量的有效数来显示除法运算的结果:

// This program demonstrates how the setprecision manipulator

// affects the way a floating-point value is displayed.

#include

#include // Header file needed to use setprecision

using namespace std;

int main()

{

double number1 = 132.364, number2 = 26.91;

double quotient = number1 / number2;

cout << quotient << endl;

cout << setprecision(5) << quotient << endl;

cout << setprecision(4) << quotient << endl;

cout << setprecision(3) << quotient << endl;

cout << setprecision(2) << quotient << endl;

cout << setprecision(1) << quotient << endl;

return 0;

}

程序输出结果:

4.91877

4.9188

4.919

4.92

4.9

5

注意,使用预标准编译器输出的结果可能与此结果不同。

程序中的第一个值显示在第 11 行,没有设置 setprecision 操作符(默认情况下,系统使用 6 个有效数显示浮点值)。后续的 cout 语句打印相同的值,但四舍五入为 5、4、3、2 和 1 个有效数。

请注意,与 setw 不同的是,setprecision 不计算小数点。例如,当使用 setprecision(5) 时,输出包含 5 位有效数,但是需要 6 个位置来显示 4.9188。

如果一个数字的值可以由少于 setprecision 指定的精度位数来表示,则操作符将不起作用。在以下语句中,dollars 的值只有 4 位数字,所以 2 个 cout 语句显示的数字都是 24.51:

double dollars = 24.51;

cout << dollars << endl;  // 显示 24.51

cout << setprecision (5) << dollars << endl; // 显示 24.51

表 1 显示了 setprecision 如何影响各种值的显示方式。请注意,如果有效数少于要显示的数字,则 setprecision 将舍入,而不是截断数字。另外还需要注意的是,末尾的零将被省略。因此,尽管指定了  setprecision(5),但是 21.40 仍显示为 21.4。

表 1 setprecision 操作符

数 字

操作符

显示的值

28.92786

setprecision(3)

28.9

21.40

setprecision(5)

21.4

109.50

setprecision(4)

109.5

34.78596

setprecision(2)

35

与 setw 字段宽度不同的是,setprecision 的精度设置将保持有效,直到更改为其他值为止。与所有格式化操作符一样,必须包含头文件 iomanip 才能使用 setprecision。

下面的程序显示了如何组合使用 setw 和 setprecision 操作符来控制显示浮点数的方式。

// This program asks for sales figures for three days.

// The total sales are calculated and displayed in a table.

#include

#include // Header file needed to use stream manipulators

using namespace std;

int main()

{

double day1, day2, day3, total;

// Get the sales for each day

cout << "Enter the sales for day 1: ";

cin >> dayl;

cout << "Enter the sales for day 2: ”;

cin >> day2;

cout << "Enter the sales for day 3: ”;

cin >> day3;

// Calculate total sales

total = day1 + day2 + day3;

// Display the sales figures

cout << "\nSales Figures\n";

cout << "-------------\n" ;

cout << setprecision (5);

cout << "Day 1: " << setw(8) << day1 << endl;

cout << "Day 2: " << setw(8) << day2 << endl;

cout << "Day 3: " << setw(8) << day3 << endl;

cout << "Total: " << setw(8) << total << endl;

return 0;

}

程序输出结果:

Enter the sales ;for day 1: 321.57

Enter the sales for day 2: 269,60

Enter the sales for day 3: 307.00

Sales Figures

-------------

Day 1: 321.57

Day 2: 269.6

Day 3: 307

Total: 898.17

该程序创建的输出,按照指示,允许显示最多 5 个有效数,并以 8 个字符的字段宽度右对齐打印。

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值