【考研每日一题8】中位数(C++)
程序员文章站
2022-07-12 23:39:33
...
题目地址:牛客网
题目描述:
中位数定义:一组数据按从小到大的顺序依次排列,处在中间位置的一个数(或最中间两个数据的平均数). 给出一组无序整数,求出中位数,如果求最中间两个数的平均数,向下取整即可(不需要使用浮点数)
输入描述:
该程序包含多组测试数据,每一组测试数据的第一行为N,代表该组测试数据包含的数据个数,1<=N<=10000. 接着N行为N个数据的输入,N=0时结束输入
输出描述:
输出中位数,每一组测试数据输出一行
示例1
输入
4 10 30 20 40 3 40 30 50 4 1 2 3 4 0
输出
25 40 2
分析:
我也不想每天做水题的,但我之前的一些资料都在学校,一直不开学也挺麻烦。
这题就求中位数就好了,注意数组下标。
代码:
#include<iostream>
#include<algorithm>
using namespace std;
int main()
{
int n;
while(cin>>n&&n!=0)
{
int a[10001];
for(int i=0;i<n;i++)
{
cin>>a[i];
}
sort(a,a+n);
if(n%2==1)cout<<a[n/2]<<endl;
else cout<<int((a[n/2-1]+a[n/2])/2)<<endl;
}
return 0;
}
2020.3.27