P1168 中位数 题解

文章目录

题目描述

给定一个长度为 N N N 的非负整数序列 A A A,对于前奇数项求中位数。

输入格式

第一行一个正整数 N N N。

第二行 N N N 个正整数 A 1 ... N A_{1\dots N} A1...N。

输出格式

共 ⌊ N + 1 2 ⌋ \lfloor \frac{N + 1}2\rfloor ⌊2N+1⌋ 行,第 i i i 行为 A 1 ... 2 i − 1 A_{1\dots 2i - 1} A1...2i−1 的中位数。

样例 #1

样例输入 #1

复制代码
7
1 3 5 7 9 11 6

样例输出 #1

复制代码
1
3
5
6

样例 #2

样例输入 #2

复制代码
7
3 1 5 9 8 7 6

样例输出 #2

复制代码
3
3
5
6

数据范围与提示

对于 20 % 20\% 20% 的数据, N ≤ 100 N \le 100 N≤100;

对于 40 % 40\% 40% 的数据, N ≤ 3000 N \le 3000 N≤3000;

对于 100 % 100\% 100% 的数据, 1 ≤ N ≤ 100000 1 \le N ≤ 100000 1≤N≤100000, 0 ≤ A i ≤ 1 0 9 0 \le A_i \le 10^9 0≤Ai≤109。

题目传送门

完整代码

cpp 复制代码
#include <vector>
#include <iostream>
#include <algorithm>
using namespace std;
vector<int> a;
int main() {
    int n;
    scanf("%d", &n);
    for (int i = 1, x; i <= n; i++) {
        scanf("%d", &x);
        a.insert(upper_bound(a.begin(), a.end(), x), x);
        if (i % 2 == 1)
            printf("%d\n", a[i - 1 >> 1]);
    }
    return 0;
}
相关推荐
水龙吟啸8 小时前
数据结构与算法随机复习–Day1
数据结构·c++·算法
SilentSamsara8 小时前
闭包的本质:Python 如何捕获自由变量
开发语言·python·青少年编程·pycharm
生成论实验室8 小时前
《事件关系阴阳博弈动力学:识势应势之道》第八篇:认知与反思关系——探索、定位与延续
人工智能·算法·架构·知识图谱·创业创新
萑澈9 小时前
智能增强与范式演进:OpenClaw 与 Hermes Agent 自我学习机制深度研究报告
学习
十五年专注C++开发9 小时前
浅谈LLVM
开发语言·c++·qt·clang·llvm
YaraMemo9 小时前
一文带你区分全局最优解和帕累托最优解
算法·5g·信息与通信·信号处理
白夜11179 小时前
C++(标签派发 Tag Dispatching)
开发语言·c++·笔记·算法
王老师青少年编程9 小时前
csp信奥赛C++高频考点专项训练之字符串 --【字符串基础】:凯撒密码
c++·字符串·csp·凯撒密码·高频考点·信奥赛·一等奖
YaraMemo9 小时前
数学优化问题中的三大转化:多目标转化为单目标,多变量转化为单变量,有约束转化为无约束
人工智能·算法·5g·信息与通信·信号处理
CSCN新手听安9 小时前
【Qt】Qt窗口(六)QMessageBox消息对话框的使用
开发语言·c++·qt