标题:中位数,哪位大佬帮我一下
只看楼主
loong2
Rank: 1
等 级:新手上路
帖 子:2
专家分:0
注 册:2017-6-1
结帖率:0
已结贴  问题点数:2 回复次数:2 
中位数,哪位大佬帮我一下
输入
1)第一行整数T表示下面有T组测试案例,每个案例占一行;


2)第二行开始的、每行第一个整数N表示这行案例有N个样本值(都为整数),数据之间以空格分隔。
输出
每个测试案例输出占一行,不保留小数。
样例输入
2
5 10 20 60 80 70
8 23 29 20 32 23 21 33 25
样例输出
60
24

哪位会写呀.我是新学编程的萌新.
搜索更多相关主题的帖子: 中位数 学编程 样本 
2017-06-01 16:04
九转星河
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
来 自:长长久久
等 级:贵宾
威 望:52
帖 子:5023
专家分:14003
注 册:2016-10-22
得分:1 
先排序试试~

[code]/*~个性签名:bug是什么意思?bug是看上去没有可能的东西实际上是有可能做到的 就是这样~2018-08-08更~*/[/code]
2017-06-01 16:37
rjsp
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
等 级:版主
威 望:507
帖 子:8890
专家分:53117
注 册:2011-1-18
得分:1 
你需要照着C++的 nth_element 的源代码写个C函数 (其实就是快排,但不需要全部有序)
min_element 就简单了

程序代码:
#include <iostream>
#include <vector>
#include <iterator>
#include <algorithm>
using namespace std;

int main( void )
{
    unsigned T;
    cin >> T;
    for( size_t i=0; i!=T; ++i )
    {
        unsigned N;
        cin >> N;
        std::vector<int> arr( N );
        std::copy_n( std::istream_iterator<int>(cin), N, arr.begin() );

        auto middle = std::next(arr.begin(),(N-1)/2);
        std::nth_element( arr.begin(), middle, arr.end() );
        if( N%2 == 1 )
        {
            cout << *middle << '\n';
        }
        else
        {
            auto middle2 = std::min_element( middle+1, arr.end() );
            cout << (*middle + *middle2)/2 << '\n';
        }
    }
}

2017-06-02 16:41



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-477543-1-1.html




关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.017418 second(s), 7 queries.
Copyright©2004-2025, BCCN.NET, All Rights Reserved