问题描述
这一道试题并不难,但是好多小伙伴写完之后提交上去发现并没能得到100分,问题出在哪里了呢?我稍微总结了一下,大概分为以下几点:
- 没有严格按照题目要求的格式进行输出
题目中要求对于整数要直接输出整数,对于可能出现的分数要输出四舍五入保留一位小数的结果,必须要严格按照这个要求来输出。题目中可能出现小数的变量只有mid(中位数)这一个,那么这个变量一定是 double 或 float 类型的变量,如果最终mid得到了一个整数值,就要强制类型转换成整型变量然后再输出,不能直接输出mid。 - 四舍五入保留一位小数的问题
这道题目在计算中位数时有可能会出现小数,但是中位数有小数的情况一定是两个整数相加之后除以二得到的,而这个操作最多只能有一位小数。所以本题中的四舍五入保留一位小数的问题可以不用单独考虑。 - 数据存储问题
这道题要求输入一串递增有序或递减有序的数列,但并不是每一个数都要用,我们需要的只是这些数中的最大值、中位数和最小值,所以没必要用一个数组把他们全部存起来。只需要根据要求在输入的时候选取有用的数值即可。
满分参考代码如下:
#include <iostream>
using namespace std;
int main() {
int n;
int max, min, t;
double mid = 0;
cin >> n;
for (int i = 1; i <= n; i++) {
if (i == 1)
cin >> max;
else if (i == n)
cin >> min;
//有偶数个数,取中间两个数的平均数
else if (n % 2 == 0 && (i == n / 2 || i == n / 2 + 1)) {
cin >> t;
mid += t / 2.0;
}
//有奇数个数,那么中位数就是最中间的那个
else if (n % 2 == 1 && i == (n + 1) / 2)
cin >> mid;
else
cin >> t; //其他数据无用
}
if (max < min) {
t = max;
max = min;
min = t;
}
//判断mid是否是整数,分别以不同形式输出
if (mid - (int)mid == 0)
cout << max << ' ' << (int)mid << ' ' << min;
else
cout << max << ' ' << mid << ' ' << min;
}