【题目链接】
ybt 1414:【17NOIP普及组】成绩
洛谷 P3954 [NOIP2017 普及组] 成绩
【题目考点】
1. 算术表达式
2. 自动类型转换
- 低精度类型与高精度类型计算结果是高精度类型
常量0.3的类型是double,常量100的类型是int,0.3*100这个表达式的值的类型是double。
【解题思路】
【注意: 数据范围】数据说明中,指明了A,B,C都是10的倍数,10的倍数乘以0.2,0.3或0.5得到的都是整数,因此本题不需要声明浮点型量,直接用整型量参与运算即可。
0.3*100的类型是double,可以转为整型输出,或保留0位小数输出,或者以%g形式输出。
【题解代码】
解法1:用cin, cout
cout的输出形式相当于printf("%g"),当浮点数有效数字少的时候,去掉小数点后末尾的0输出。
#include<bits/stdc++.h>
using namespace std;
int main()
{
int a, b, c;
cin >> a >> b >> c;
cout << a*0.2+b*0.3+c*0.5;
return 0;
}
解法2:用scanf, printf("%g")
#include<bits/stdc++.h>
using namespace std;
int main()
{
int a, b, c;
scanf("%d %d %d", &a, &b, &c);
printf("%g", a*0.2+b*0.3+c*0.5);
return 0;
}
解法3:用scanf, printf("%d")
将结果强制转为整型
#include<bits/stdc++.h>
using namespace std;
int main()
{
int a, b, c;
scanf("%d %d %d", &a, &b, &c);
printf("%d", int(a*0.2+b*0.3+c*0.5));//强制转为整型
return 0;
}
解法4:用scanf, printf("%f")
保留0位小数
#include<bits/stdc++.h>
using namespace std;
int main()
{
int a, b, c;
scanf("%d %d %d", &a, &b, &c);
printf("%.0f", a*0.2+b*0.3+c*0.5);//保留0位小数
return 0;
}