题解 | #中位数#

中位数

https://www.nowcoder.com/practice/2364ff2463984f09904170cf6f67f69a

#include <iostream>
#include <algorithm>
using namespace std;
int Data[10000];
int main() {
    int num;
    while (cin >> num) {
        if(num==0)
        {
            return 0;
        }
        for (int i = 0; i < num; i++) {
            cin >> Data[i];
        }
        if (num % 2 == 0) {
            // 如果数组长度是偶数,需要找到中间两个数
            std::nth_element(Data, Data + num / 2, Data + num);
            int mid1 = Data[num / 2];
            std::nth_element(Data, Data + num / 2 - 1, Data + num);
            int mid2 = Data[num / 2 - 1];
            cout << (mid1 + mid2) / 2 << endl;
        } else {
            // 如果数组长度是奇数,只需要找到中间那个数
            std::nth_element(Data, Data + num / 2, Data + num);
            cout << Data[num / 2] << endl;
        }

    }
}
// 64 位输出请用 printf("%lld")

使用c++的std::nth_element,连续两个不会影响各自的绝对位置

全部评论

相关推荐

牛客73617529...:无端端被你骂一句
点赞 评论 收藏
分享
06-15 20:57
已编辑
门头沟学院 Java
CARLJOSEPH...:年轻人有傲气很正常,但是建议工作前洗净傲气。 说实在的,什么奖学金什么奖项的都很一般。尊重你的老师,在有时间的时候去上课,真遇到走不开的事,请态度端正地向你的老师说明情况,请求请假。我相信任何一个有师德的老师都会允许的(我的老师就是这样)。
点赞 评论 收藏
分享
陆续:不可思议 竟然没那就话 那就我来吧 :你是我在牛客见到的最美的女孩
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务