[ABC107D/ARC101B] Median of Medians 解题记录

2024-04-02 21:52

本文主要是介绍[ABC107D/ARC101B] Median of Medians 解题记录,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

[ABC107D/ARC101B] Median of Medians 解题记录


题意简述

定义一个长度为  M M M 的序列的中位数为这个序列中第  ⌊ M 2 ⌋ + 1 \lfloor \frac{M}{2} \rfloor +1 2M+1 小的数。
现在有一个长度为  N N N 的序列  A A A,将  A A A 的所有子段的中位数取出来作为一个序列  S S S,问序列  S S S 的中位数是多少。


题目分析

早期ABC真的好变态
中位数有个性质:

  • 如果 x x x 是序列的中位数,那么这个序列中至少有一半的数 ≥ x \geq x x
    本题是求“中位数的中位数”。因为中位数具有单调性,所以考虑二分答案。
    先将 A A A 复制到另一个数组 B B B 中,将 B B B 排序。枚举答案在 B B B 中的下标 i d x idx idx
    check 怎么写?
    对于一个序列 [ l , r ] [l,r] [l,r] 和枚举的答案 x x x,我们把其中 > x >x >x 的数标记为 1 1 1 ≤ x \leq x x 的数标记为 − 1 -1 1,如果所有标记的和 ≥ 0 \geq0 0,那么就说明这个序列的中位数肯定 ≥ x \geq x x
    序列 A A A 中共有 n × ( n + 1 ) 2 \frac{n\times(n+1)}{2} 2n×(n+1) 个区间,如果其中有一半的区间的中位数 ≥ B i d x \geq B_{idx} Bidx(即有一半的区间的区间和 ≥ 0 \geq0 0),那么就说明真正的中位数比 B i d x B_{idx} Bidx 大,向有缩减区间,反之亦然。
    s i s_i si 表示前 i i i 个标记的和,求“有多少个区间的和 ≥ 0 \geq0 0”就变成了有多少个 s i ≥ s j s_i\geq s_j sisj
    可以使用类似逆序对的思想,用树状数组统计 s s s 不同值域的数量。
    注意:由于 s i s_i si 可能小于 0 0 0,所以需要整体加上 n n n

AC Code
#include<bits/stdc++.h>
#define arrout(a,n) rep(i,1,n)std::cout<<a[i]<<" "
#define arrin(a,n) rep(i,1,n)std::cin>>a[i]
#define rep(i,x,n) for(int i=x;i<=n;i++)
#define dep(i,x,n) for(int i=x;i>=n;i--)
#define erg(i,x) for(int i=head[x];i;i=e[i].nex)
#define dbg(x) std::cout<<#x<<":"<<x<<" "
#define mem(a,x) memset(a,x,sizeof a)
#define all(x) x.begin(),x.end()
#define arrall(a,n) a+1,a+1+n
#define PII std::pair<int,int>
#define m_p std::make_pair
#define u_b upper_bound
#define l_b lower_bound
#define p_b push_back
#define CD const double
#define CI const int
#define int long long
#define il inline
#define ss second
#define ff first
#define itn int
CI N=2e5+5;
int n,a[N],s[N],c[N<<1],d[N],b[N];
int lowbit(int x) {return x&(-x);
}
void update(int x,int v) {for(int i=x;i<=n*2;i+=lowbit(i)) {c[i]+=v;}
}
int query(int x) {int b=0;for(int i=x;i;i-=lowbit(i)) {b+=c[i];}return b;
}
bool check(int x) {int cnt=0;rep(i,1,n) {s[i]=s[i-1];if(std::l_b(arrall(b,n),a[i])-b<=x) {//a[i]在b中的下标小于等于枚举的下标,因为b是有序的,所以等同于a[i]<=xs[i]--;} else {s[i]++;}}mem(c,0);rep(i,1,n) {update(s[i-1]+n,1ll);cnt+=i-query(s[i]+n);//统计到s[i]位置有多少个“逆序对”}return cnt>=n*(n+1)/2/2+1;//真实答案大于等于b[x]
}
signed main() {std::cin>>n;arrin(a,n);rep(i,1,n){b[i]=a[i];}std::sort(arrall(b,n));int l=0,r=n,idx;while(l<=r) {int mid=l+r>>1;if(check(mid)) {//mid小了,向大的缩减r=mid-1;idx=mid;} else {l=mid+1;}}std::cout<<b[idx];return 0;
}

这篇关于[ABC107D/ARC101B] Median of Medians 解题记录的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/871151

相关文章

Python获取中国节假日数据记录入JSON文件

《Python获取中国节假日数据记录入JSON文件》项目系统内置的日历应用为了提升用户体验,特别设置了在调休日期显示“休”的UI图标功能,那么问题是这些调休数据从哪里来呢?我尝试一种更为智能的方法:P... 目录节假日数据获取存入jsON文件节假日数据读取封装完整代码项目系统内置的日历应用为了提升用户体验,

Spring Boot 配置文件之类型、加载顺序与最佳实践记录

《SpringBoot配置文件之类型、加载顺序与最佳实践记录》SpringBoot的配置文件是灵活且强大的工具,通过合理的配置管理,可以让应用开发和部署更加高效,无论是简单的属性配置,还是复杂... 目录Spring Boot 配置文件详解一、Spring Boot 配置文件类型1.1 applicatio

MySQL INSERT语句实现当记录不存在时插入的几种方法

《MySQLINSERT语句实现当记录不存在时插入的几种方法》MySQL的INSERT语句是用于向数据库表中插入新记录的关键命令,下面:本文主要介绍MySQLINSERT语句实现当记录不存在时... 目录使用 INSERT IGNORE使用 ON DUPLICATE KEY UPDATE使用 REPLACE

Python 中的异步与同步深度解析(实践记录)

《Python中的异步与同步深度解析(实践记录)》在Python编程世界里,异步和同步的概念是理解程序执行流程和性能优化的关键,这篇文章将带你深入了解它们的差异,以及阻塞和非阻塞的特性,同时通过实际... 目录python中的异步与同步:深度解析与实践异步与同步的定义异步同步阻塞与非阻塞的概念阻塞非阻塞同步

Python Dash框架在数据可视化仪表板中的应用与实践记录

《PythonDash框架在数据可视化仪表板中的应用与实践记录》Python的PlotlyDash库提供了一种简便且强大的方式来构建和展示互动式数据仪表板,本篇文章将深入探讨如何使用Dash设计一... 目录python Dash框架在数据可视化仪表板中的应用与实践1. 什么是Plotly Dash?1.1

Spring Boot中定时任务Cron表达式的终极指南最佳实践记录

《SpringBoot中定时任务Cron表达式的终极指南最佳实践记录》本文详细介绍了SpringBoot中定时任务的实现方法,特别是Cron表达式的使用技巧和高级用法,从基础语法到复杂场景,从快速启... 目录一、Cron表达式基础1.1 Cron表达式结构1.2 核心语法规则二、Spring Boot中定

国内环境搭建私有知识问答库踩坑记录(ollama+deepseek+ragflow)

《国内环境搭建私有知识问答库踩坑记录(ollama+deepseek+ragflow)》本文给大家利用deepseek模型搭建私有知识问答库的详细步骤和遇到的问题及解决办法,感兴趣的朋友一起看看吧... 目录1. 第1步大家在安装完ollama后,需要到系统环境变量中添加两个变量2. 第3步 “在cmd中

Spring Retry 实现乐观锁重试实践记录

《SpringRetry实现乐观锁重试实践记录》本文介绍了在秒杀商品SKU表中使用乐观锁和MybatisPlus配置乐观锁的方法,并分析了测试环境和生产环境的隔离级别对乐观锁的影响,通过简单验证,... 目录一、场景分析 二、简单验证 2.1、可重复读 2.2、读已提交 三、最佳实践 3.1、配置重试模板

在 Spring Boot 中使用异步线程时的 HttpServletRequest 复用问题记录

《在SpringBoot中使用异步线程时的HttpServletRequest复用问题记录》文章讨论了在SpringBoot中使用异步线程时,由于HttpServletRequest复用导致... 目录一、问题描述:异步线程操作导致请求复用时 Cookie 解析失败1. 场景背景2. 问题根源二、问题详细分

关于Spring @Bean 相同加载顺序不同结果不同的问题记录

《关于Spring@Bean相同加载顺序不同结果不同的问题记录》本文主要探讨了在Spring5.1.3.RELEASE版本下,当有两个全注解类定义相同类型的Bean时,由于加载顺序不同,最终生成的... 目录问题说明测试输出1测试输出2@Bean注解的BeanDefiChina编程nition加入时机总结问题说明