Gym - 102500E - Expeditious Cubing(基础数学)
题目链接
题目大意:一个人的成绩计算是舍弃5个成绩中的最高分与最低分然后计算平均值,现在你知道了4个值,和一个目标值, 问第5个值最大是多少的情况下平均值可以比目标值小。
1.当4个值中的最大的三个值的平均值比目标值小的时候,无论第5个值是多大都行。
2.当4个值中的最小的三个值的平均值比目标值大的时候,无论第5个值是多小都不行。
3.所以说我们只要在最小值与次小值之间找一个符合题意的数就可以了。
PS:这题主要问题出在浮点数的判断误差上面,可以使用整型避免出现误差,也可以考虑精度问题之后再进行浮点数比较。
int main() {
int arr[5];
for (int i = 0, a, b; i<5; ++i) {
scanf("%d.%d", &a, &b);
arr[i] = 100*a+b;
}
sort(arr, arr+4);
if (arr[1]+arr[2]+arr[3] <= arr[4]*3) printf("infinite\n");
else if (arr[0]+arr[1]+arr[2] > arr[4]*3) printf("impossible\n");
else {
int tmp = arr[4]*3-arr[1]-arr[2];
double ans = tmp/100.0+eps;
printf("%.2f\n", ans);
}
return 0;
}
int cmp(double k) {
if (k>eps) return 1;
else if (k<-eps) return -1;
return 0;
}
int main() {
double a[5];
for (int i = 0; i<5; ++i) scanf("%lf", &a[i]);
sort(a, a+4);
double x = 3*a[4]-a[1]-a[2];
if (cmp(x-a[0])==-1) printf("impossible\n");
else if (cmp(x-a[3])>=0) printf("infinite\n");
else printf("%.2f\n", x);
return 0;
}