通过uva中位数计划

时间:2015-04-22 19:34:14

标签: c++ median

这是我第一次使用在线评判,我尝试了一个简单的程序来熟悉环境。

这是question

我解决了以下问题,但得到了错误的答案!

#include<stdio.h>
#include<math.h>
#include<iostream>

int main()
{
int t;
int n;
int num[10];
int i,j,temp;
int s;
int fmid;
std::cin >>t;
int iter=0;
while (iter<t)
{
std::cin>>n;
if (n!=-1){
for(i=0;i<n;i++)
std::cin>>num[i];

for( i=0;i<n-1;i++)

for(j=i+1;j<n;j++)
if(num[i]>num[j])
{temp=num[i];
num[i]=num[j];
num[j]=temp;
}

s=0;
if (n%2 ==0)
{
int mid=n/2-1;
int  midd=mid+1;

s=(num[mid]+num[midd])/2;
fmid=s;
}

else
{s=ceil(n/2);
fmid=num[s];}

std::cout<<fmid;
}
iter++;

}

return 0;

}

非常感谢任何建议。

由于

1 个答案:

答案 0 :(得分:1)

我会读取所有数字,将它们存储在数组中,然后使用std::sort中的<algorithm>对数组进行排序

请在下面找到我的代码:

#include <stdio.h>
#include <math.h>
#include <iostream>
#include <algorithm>

int arr[10];

int main()
{
    int N;
    while ((std::cin >> N) && (N!=-1)){
        for(int i=0;i<N;i++) {
            std::cin >> arr[i];
        }
        std::sort(arr,arr+N);
        if(N%2 == 1){
            std::cout << arr[N/2] << std::endl;
        }
        else {
            double ans = ((double)arr[N/2] + (double)arr[(N/2)-1]) / 2.0;
            std::cout << ans << std::endl;
        }
    }

    return 0;
}

我希望它适合你。

我可以知道问题编号吗?我会尝试提交并给你一个AC解决方案。