[国家集训队]middle
[国家集训队]middle
解法
开\(n\)颗线段树,将第\(i\)颗线段树中大于等于第\(i\)小的数权值赋为1,其他的则为-1,对于每个区间维护一个区间和,最大前缀和,最大后缀和。
然后二分答案,查询二分到的答案对应线段树。
\(设s=[a,b-1]的最大后缀和+[b,c]的区间和+[c+1,d]的最大前缀和\)
若\(s\geq 0\),则答案可能更大,否则答案必须变小,仔细想想为什么。
这样不断二分即可。
考虑到开不下那么多线段树,而若排序后相邻线段树维护的序列只有一个元素不同,所以我们考虑用主席树来维护。
然后其实不需要离散化,离散化也没问题。
完整代码
#include<bits/stdc++.h>
#define rg register
#define il inline
using namespace std;
void ssort(int &a,int &b,int &c,int &d){
if(a>b)swap(a,b);if(a>c)swap(a,c);if(a>d)swap(a,d);
if(b>c)swap(b,c);if(b>d)swap(b,d);
if(c>d)swap(c,d);
}
const int N=3e4;
struct code{
int x,id;
}a[N];
struct tree{
int x,l,r,L,R,sum;
}t[N*100],ans,fz;
int cmp(code x,code y){return x.x<y.x;}
int root[N],cnt,aa,bb,cc,dd,n;
il void pushup(tree &no,tree l,tree r){
no.L=max(l.L,l.sum+r.L);
no.R=max(r.R,r.sum+l.R);
no.sum=l.sum+r.sum;
}
int build(int l,int r){
int no=++cnt;
if(l==r){
t[no].x=t[no].sum=t[no].L=t[no].R=1;
return no;
}
int mid=l+r>>1;
t[no].l=build(l,mid);
t[no].r=build(mid+1,r);
pushup(t[no],t[t[no].l],t[t[no].r]);
return no;
}
int modify(int last,int l,int r,int k){
int no=++cnt;
if(l==r){
t[no].x=t[no].sum=-1;
return no;
}
t[no].l=t[last].l;
t[no].r=t[last].r;
int mid=l+r>>1;
if(k<=mid)t[no].l=modify(t[last].l,l,mid,k);
else t[no].r=modify(t[last].r,mid+1,r,k);
pushup(t[no],t[t[no].l],t[t[no].r]);
return no;
}
void query(int no,int l,int r,int L,int R){
if(l>=L&&r<=R){
pushup(ans,ans,t[no]);
return ;
}
if(l>R||r<L||R<L)return ;
int mid=l+r>>1;
query(t[no].l,l,mid,L,R);
query(t[no].r,mid+1,r,L,R);
}
int check(int x){
int s=0;
ans=fz;query(root[x],1,n,aa,bb-1);s+=ans.R;
ans=fz;query(root[x],1,n,bb,cc);s+=ans.sum;
ans=fz;query(root[x],1,n,cc+1,dd);s+=ans.L;
return s>=0;
}
int main(){
cin>>n;
for(int i=1;i<=n;++i){
scanf("%d",&a[i].x);
a[i].id=i;
}
sort(a+1,a+n+1,cmp);
root[0]=build(1,n);
for(int i=1;i<=n;++i)
root[i]=modify(root[i-1],1,n,a[i].id);
int q,x=0;
cin>>q;
while(q--){
scanf("%d%d%d%d",&aa,&bb,&cc,&dd);
aa=(aa+x)%n+1;bb=(bb+x)%n+1;cc=(cc+x)%n+1;dd=(dd+x)%n+1;
ssort(aa,bb,cc,dd);
int l=0,r=n;
while(l!=r){
int mid=l+r>>1;
if(check(mid+1))l=mid+1;
else r=mid;
}
x=a[l+1].x;
printf("%d\n",x);
}
}
[国家集训队]middle的更多相关文章
- [国家集训队]middle 解题报告
[国家集训队]middle 主席树的想法感觉挺妙的,但是这题数据范围这么小,直接分块草过去不就好了吗 二分是要二分的,把\(<x\)置\(-1\),\(\ge x\)的置\(1\),于是我们需要 ...
- P2839 [国家集训队]middle
P2839 [国家集训队]middle 好妙的题啊,,,, 首先二分一个答案k,把数列里>=k的数置为1,=0就是k>=中位数,<0就是k<中位数 数列的最大和很好求哇 左边的 ...
- CF484E Sign on Fence && [国家集训队]middle
CF484E Sign on Fence #include<bits/stdc++.h> #define RG register #define IL inline #define _ 1 ...
- 【LG2839】[国家集训队]middle
[LG2839][国家集训队]middle 题面 洛谷 题解 按照求中位数的套路,我们二分答案\(mid\),将大于等于\(mid\)的数设为\(1\),否则为\(-1\). 若一个区间和大于等于\( ...
- BZOJ.2653.[国家集训队]middle(可持久化线段树 二分)
BZOJ 洛谷 求中位数除了\(sort\)还有什么方法?二分一个数\(x\),把\(<x\)的数全设成\(-1\),\(\geq x\)的数设成\(1\),判断序列和是否非负. 对于询问\(( ...
- luogu2839 [国家集训队]middle
题目链接:洛谷 题目大意:给定一个长度为$n$的序列,每次询问左端点在$[a,b]$,右端点在$[c,d]$的所有子区间的中位数的最大值.(强制在线) 这里的中位数定义为,对于一个长度为$n$的序列排 ...
- 解题:国家集训队 Middle
题面 求中位数的套路:二分,大于等于的设为1,小于的设为-1 于是可以从小到大排序后依次加入可持久化线段树,这样每次只会变化一个位置 那左右端点是区间怎么办? 先把中间的算上,然后维护每个区间左右两侧 ...
- [洛谷P2839][国家集训队]middle
题目大意:给你一个长度为$n$的序列$s$.$Q$个询问,问在$s$中的左端点在$[a,b]$之间,右端点在$[c,d]$之间的子段中,最大的中位数. 强制在线. 题解:区间中位数?二分答案,如果询问 ...
- Luogu 2839 [国家集训队]middle
感觉这题挺好的. 首先对于中位数最大有一个很经典的处理方法就是二分,每次二分一个数组中的下标$mid$,然后我们把$mid$代回到原来的数组中检查,如果一个数$a_{i} \geq mid$,那么就把 ...
随机推荐
- Android 自定义底部公用菜单
注释:此案例主要展示自定义底部菜单,一处封装处处调用.使用起来相当方便 一.初始的Activity package com.example.myapi.buttommenu; import andro ...
- P2157 [SDOI2009]学校食堂Dining
题目描述 小F 的学校在城市的一个偏僻角落,所有学生都只好在学校吃饭.学校有一个食堂,虽然简陋,但食堂大厨总能做出让同学们满意的菜肴.当然,不同的人口味也不一定相同,但每个人的口味都可以用一个非负整数 ...
- poj 3169 Layout(线性差分约束,spfa:跑最短路+判断负环)
Layout Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 15349 Accepted: 7379 Descripti ...
- day32
今日内容 1.基于TCP协议(通信循环) 2.基于TCP协议(连接循环) 3.粘包问题 4.模拟SSH实现远程执行命令 服务器端 ################################### ...
- group by having 和where区别联系
原文参考:http://www.51ou.com/browse/msyql/43081.html having 和 where 参考 http://blog.csdn.net/yexudengzhid ...
- Swoole Timer 的应用
目录 你好,Swoole Timer 应用场景 参考文档 你好,Swoole PHP 的协程高性能网络通信引擎,使用 C/C++ 语言编写,提供了多种通信协议的网络服务器和客户端模块. Swoole ...
- 03-Python执行方式和Pycharm设置
https://www.python.org/ 单词列表 * error 错误 * name 名字 * defined 已经定义 * syntax 语法 * invalid 无效 * Indentat ...
- 20155229《网络对抗技术》Exp8:Web基础
实验内容 (1).Web前端HTML 能正常安装.启停Apache.理解HTML,理解表单,理解GET与POST方法,编写一个含有表单的HTML. (2).Web前端javascipt 理解JavaS ...
- 20155321 《网络对抗》 Exp6 信息搜集与漏洞扫描
20155321 <网络对抗> Exp6 信息搜集与漏洞扫描 实验内容 信息搜集 whois 在kali终端输入whois 网址,查看注册的公司.服务.注册省份.传真.电话等信息 dig或 ...
- 《Flask Web开发实战:入门、进阶与原理解析(李辉著 )》PDF+源代码
一句话评价: 这可能是市面上(包括国外出版的)你能找到最好的讲Flask的书了 下载:链接: https://pan.baidu.com/s/1ioEfLc7Hc15jFpC-DmEYBA 提取码: ...