一,代码
#include<iostream>
#include<stdio.h>//scanf()
#include<iomanip>//setprecision(n)和setiosflags(ios::fixed)
using namespace std;
int main()
{
float score_1, score_2, score_3;//三个成绩
float sum = 0;
while(~scanf("%f %f %f", &score_1, &score_2, &score_3))
{
sum = (score_1 + score_2 + score_3) / 3.0;
cout<<setprecision(2)<<setiosflags(ios::fixed)<<sum<<endl;
}//保留两位小数输出
return 0;
}
输入
99 92 90.3
输出
93.77
二,分析
1,setprecision(n) 与 setiosflags(ios::fixed) 合用可控制小数点后位数 n
头文件是#include<iomanip>
2,单一个 setprecision(n) 表示有效位数,包括整数部分
3,fixed输出小数点后六位小数,且能消除浮点数科学计数法
比如这样
#include<iostream>
#include<stdio.h>//scanf()
#include<iomanip>//setprecision(n)和setiosflags(ios::fixed)
using namespace std;
int main()
{
float n = 3.14159263;
cout<<fixed<<n<<endl;
return 0;
}
输出
3.141593
5,代码第10行while(~scanf("%f %f %f", &score_1, &score_2, &score_3))
与while(scanf("%f %f %f", &score_1, &score_2, &score_3) != EOF)等价
6,补充C的方式
#include<iostream>
#include<stdio.h>//scanf(), printf()
using namespace std;
int main()
{
float score_1, score_2, score_3;//三个成绩
float sum = 0;
while(~scanf("%f %f %f", &score_1, &score_2, &score_3))
{
sum = (score_1 + score_2 + score_3) / 3.0;
printf("%.2f", sum);
}//保留两位小数输出
return 0;
}
7,第三种方法:
#include<iostream>
#include<math.h>//round()
using namespace std;
int main()
{
double x;
cin>>x;
cout<<round(x*100) / 100.0<<endl;
return 0;
}
round()函数四舍五入到整数位,可先乘10^a,再除以10^a来保留a位小数
2854





