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;
}
相关推荐
尘似鹤几秒前
Uboot移植--修改lcd和网络驱动
linux·学习·uboot
闻缺陷则喜何志丹几秒前
【C++组合数学】P8106 [Cnoi2021] 数学练习|普及+
c++·数学·洛谷·组合数学
ALex_zry4 分钟前
C++ const成员函数详解:原理、应用与最佳实践
c++
iAkuya5 分钟前
(leetcode)力扣100 22相交链表(双指针)
算法·leetcode·链表
d111111111d7 分钟前
STM32平衡车工具-匿名助手+虚拟串口如何使用。
笔记·stm32·单片机·嵌入式硬件·学习
式5168 分钟前
大模型学习基础(七)强化学习概念回顾
学习
chao18984415 分钟前
基于MATLAB的ADI方法求解偏微分方程详解
开发语言·算法·matlab
絔宝17 分钟前
在eclipse中创建Maven项目-用于学习Selenium 自动化测试
学习·selenium·eclipse·maven
智驱力人工智能20 分钟前
超越识别 将光学字符识别(OCR)技术转化为可靠业务能力的交付思维 光学字符识别 金融票据OCR识别系统 物流单据自动识别技术
人工智能·opencv·算法·目标检测·ocr·边缘计算
程序猿零零漆30 分钟前
Spring之旅 - 记录学习 Spring 框架的过程和经验(三)Bean的依赖注入配置、Spring的其它配置标签
java·学习·spring