bzoj3524:[Poi2014]Couriers
传送门
主席树裸题,考虑出现一半次数以上的数一定是这个区间的中位数,查询中位数再判断一下中位数出现的次数就好了
注意要离散化
代码:
#include<cstdio>
#include<iostream>
#include<algorithm>
#include<tr1/unordered_map>
using namespace std;
void read(int &x) {
char ch; bool ok;
for(ok=0,ch=getchar(); !isdigit(ch); ch=getchar()) if(ch=='-') ok=1;
for(x=0; isdigit(ch); x=x*10+ch-'0',ch=getchar()); if(ok) x=-x;
}
#define rg register
const int maxn=5e5+10;tr1::unordered_map<int,int>mp;
int n,m,d[maxn],w[maxn],id,now,nid[maxn];
int rt[maxn*4],ls[maxn*20],rs[maxn*20],sum[maxn*20];
void update(int x){sum[x]=sum[ls[x]]+sum[rs[x]];}
void change(int &k,int x,int l,int r,int a)
{
k=++id,sum[k]=sum[x],ls[k]=ls[x],rs[k]=rs[x];
if(l==r){sum[k]++;return ;}
int mid=(l+r)>>1;
if(a<=mid)change(ls[k],ls[x],l,mid,a);
else change(rs[k],rs[x],mid+1,r,a);
update(k);
}
int get(int k,int x,int l,int r,int a,int b)
{
if(l==r)return sum[k]-sum[x]>b?nid[l]:0;
int mid=(l+r)>>1,now=sum[ls[k]]-sum[ls[x]];
if(now>=a)return get(ls[k],ls[x],l,mid,a,b);
else return get(rs[k],rs[x],mid+1,r,a-now,b);
}
int main()
{
read(n),read(m);for(rg int i=1;i<=n;i++)read(d[i]),w[i]=d[i];sort(w+1,w+n+1);
for(rg int i=1;i<=n;i++)if(w[i]!=w[i-1])mp[w[i]]=++now,nid[now]=w[i];
for(rg int i=1;i<=n;i++)rt[i]=rt[i-1],change(rt[i],rt[i],1,now,mp[d[i]]);
for(rg int i=1,x,y;i<=m;i++)read(x),read(y),printf("%d\n",get(rt[y],rt[x-1],1,now,(y-x+1)/2+1,(y-x+1)/2));
}
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 如何调用 DeepSeek 的自然语言处理 API 接口并集成到在线客服系统
· 【译】Visual Studio 中新的强大生产力特性
· 2025年我用 Compose 写了一个 Todo App