代码1:
#include <bits/stdc++.h>
using namespace std;
double a[100001];
int main() {
int n;
cin >> n;
for (int i = 1; i <= n; i++) {
cin >> a[i];
}
sort(a + 1, a + n + 1);
double sum = 0;
for (int i = 2; i < n; i++) {
sum += a[i];
}
double maxn = 0;
sum /= (n - 2);
for (int i = 2; i < n; i++) {
if (fabs(a[i] - sum) > maxn) {
maxn = fabs(a[i] - sum);
}
}
cout << fixed << setprecision(2) << sum << " " << maxn;
return 0;
}
代码2:
#include <bits/stdc++.h>
using namespace std;
double a[1000005];
int main() {
int n, maxi = 1, mini = 1;
double y = 0, maxn = -1, sum = 0;
cin >> n;
for (int i = 1; i <= n; i ++) {
cin >> a[i];
sum += a[i];
if (a[i] > a[maxi]) maxi = i;
if (a[i] < a[mini]) mini = i;
}
y = (sum - a[maxi] - a[mini]) / (n - 2.0);
for (int i = 1; i <= n; i ++) {
if (i != maxi && i != mini) {
if (fabs(a[i] - y) > maxn) maxn = fabs(a[i] - y);
}
}
printf("%.2lf %.2lf", y, maxn);
return 0;
}