BZOJ#1303中位数图
[CQOI2009]中位数图
因为是排列,不会出现相同的数字,把比b小的赋值为1,大于b的赋值为-1,则要是b为中位数必然这一段的和为0,(注意b的位置)
代码:
const int N=200010;
int a[N];
int s[N];
void solve(int Case) {
int n,b;
cin>>n>>b;
for(int i=1;i<=n;i++) cin>>a[i];
int p=-1;
for(int i=1;i<=n;i++){
if(a[i]<b) s[i]=1;
else if(a[i]>b) s[i]=-1;
if(a[i]==b) p=i;
}
for(int i=1;i<=n;i++) s[i]+=s[i-1];
map<int,int> mp;
mp[0]++;
int res=0;
for(int i=1;i<=n;i++){
if(i>=p){
res+=mp[s[i]];
}
if(i<p) mp[s[i]]++;
}
cout<<res<<nline;
}
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 地球OL攻略 —— 某应届生求职总结
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· 提示词工程——AI应用必不可少的技术
· .NET周刊【3月第1期 2025-03-02】