洛谷P2839 [国家集训队]middle 主席树_二分
Code:
#include <cstdio>
#include <algorithm>
#include <cstring>
#include <string>
#include <vector>
using namespace std; void setIO(string a)
{
string in=a+".in",out=a+".out";
freopen(in.c_str(),"r",stdin);
//freopen(out.c_str(),"w",stdout);
} #define maxn 210000
int arr[maxn],A[maxn],root[maxn],n;
vector<int>position[maxn];
struct Segment_Tree
{
#define max_Tree 21000*100
int lson[max_Tree],rson[max_Tree],cnt;
int sumv[max_Tree],lmax[max_Tree],rmax[max_Tree];
void pushup(int o)
{
sumv[o]=sumv[lson[o]]+sumv[rson[o]];
lmax[o]=max(lmax[lson[o]],sumv[lson[o]]+lmax[rson[o]]);
rmax[o]=max(rmax[rson[o]],sumv[rson[o]]+rmax[lson[o]]);
}
void build(int l,int r,int &o)
{
if(l>r)return;
o=++cnt;
if(l==r)
{
sumv[o]=lmax[o]=rmax[o]=1;
return;
}
int mid=(l+r)>>1;
build(l,mid,lson[o]);
build(mid+1,r,rson[o]);
pushup(o);
}
int update(int l,int r,int o,int pos) //modify val[pos] from 1 to -1
{
int oo=++cnt;
int mid=(l+r)>>1;
sumv[oo]=sumv[o];
lson[oo]=lson[o];
rson[oo]=rson[o];
if(l==r)
{
sumv[oo]=-1;
lmax[oo]=rmax[oo]=0;
return oo;
}
if(pos<=mid) lson[oo]=update(l,mid,lson[o],pos);
else rson[oo]=update(mid+1,r,rson[o],pos);
pushup(oo);
return oo;
}
int query_sum(int l,int r,int o,int L,int R)
{
if(l>r||r<L||l>R)return 0;
if(l>=L&&r<=R) return sumv[o];
int mid=(l+r)>>1;
return query_sum(l,mid,lson[o],L,R)+query_sum(mid+1,r,rson[o],L,R);
}
int query_left(int l,int r,int o,int L,int R)
{
if(l>r||r<L||l>R)return 0;
if(l>=L&&r<=R) return lmax[o];
int mid=(l+r)>>1;
return max(query_left(l,mid,lson[o],L,R),query_sum(l,mid,lson[o],L,R)+query_left(mid+1,r,rson[o],L,R));
}
int query_right(int l,int r,int o,int L,int R)
{
if(l>r||r<L||l>R)return 0;
if(l>=L&&r<=R) return rmax[o];
int mid=(l+r)>>1;
return max(query_right(mid+1,r,rson[o],L,R),query_sum(mid+1,r,rson[o],L,R)+query_right(l,mid,lson[o],L,R));
}
bool check(int a,int b,int c,int d,int tps)
{
int sum1=query_sum(1,n,root[tps],b,c);
int sum2=query_right(1,n,root[tps],a,b-1);
int sum3=query_left(1,n,root[tps],c+1,d);
if(sum1+sum2+sum3>=0)
return true;
return false;
}
}tree;
int main()
{
//setIO("input");
scanf("%d",&n);
for(int i=1;i<=n;++i) scanf("%d",&arr[i]);
for(int i=1;i<=n;++i) A[i]=arr[i];
sort(A+1,A+1+n);
for(int i=1;i<=n;++i) arr[i]=lower_bound(A+1,A+1+n,arr[i])-A; //离散编号
for(int i=1;i<=n;++i) position[arr[i]].push_back(i);
sort(arr+1,arr+1+n); int pre=arr[1];
tree.build(1,n,root[pre]); for(int i=2;i<=arr[n];++i)
{
int a=root[i-1];
for(int v=0;v<position[i-1].size();++v) a=tree.update(1,n,a,position[i-1][v]);
root[i]=a;
} int q,a,b,c,d,lastans=0,que[10];
scanf("%d",&q);
while(q--)
{
for(int i=1;i<=4;++i) scanf("%d",&que[i]),que[i]=(que[i]+lastans)%n+1;
sort(que+1,que+1+4);
a=que[1],b=que[2],c=que[3],d=que[4]; int l=1,r=n,mid,ans=1;
while(l<=r)
{
mid=(l+r)>>1;
if(tree.check(a,b,c,d,mid)) l=mid+1,ans=mid;
else r=mid-1;
}
lastans=A[ans];
printf("%d\n",lastans);
}
return 0;
}
洛谷P2839 [国家集训队]middle 主席树_二分的更多相关文章
- [洛谷P2839][国家集训队]middle
题目大意:给你一个长度为$n$的序列$s$.$Q$个询问,问在$s$中的左端点在$[a,b]$之间,右端点在$[c,d]$之间的子段中,最大的中位数. 强制在线. 题解:区间中位数?二分答案,如果询问 ...
- [洛谷2839/国家集训队]middle
Description 一个长度为n的序列a,设其排过序之后为b,其中位数定义为b[n/2],其中a,b从0开始标号,除法取下整.给你一个长度为n的序列s.回答Q个这样的询问:s的左端点在[a,b]之 ...
- 2018.06.29 洛谷P1505 [国家集训队]旅游(树链剖分)
旅游 题目描述 Ray 乐忠于旅游,这次他来到了T 城.T 城是一个水上城市,一共有 N 个景点,有些景点之间会用一座桥连接.为了方便游客到达每个景点但又为了节约成本,T 城的任意两个景点之间有且只有 ...
- 洛谷P1505 [国家集训队]旅游(树剖+线段树)
传送门 这该死的码农题…… 把每一条边变为它连接的两个点中深度较浅的那一个,然后就是一堆单点修改/路径查询,不讲了 这里就讲一下怎么搞路径取反,只要打一个标记就好了,然后把区间和取反,最大最小值交换然 ...
- P2839 [国家集训队]middle
P2839 [国家集训队]middle 好妙的题啊,,,, 首先二分一个答案k,把数列里>=k的数置为1,=0就是k>=中位数,<0就是k<中位数 数列的最大和很好求哇 左边的 ...
- 模板—点分治A(容斥)(洛谷P2634 [国家集训队]聪聪可可)
洛谷P2634 [国家集训队]聪聪可可 静态点分治 一开始还以为要把分治树建出来……• 树的结构不发生改变,点权边权都不变,那么我们利用刚刚的思路,有两种具体的分治方法.• A:朴素做法,直接找重心, ...
- 洛谷 P2634 [国家集训队]聪聪可可-树分治(点分治,容斥版) +读入挂+手动O2优化吸点氧才过。。。-树上路径为3的倍数的路径数量
P2634 [国家集训队]聪聪可可 题目描述 聪聪和可可是兄弟俩,他们俩经常为了一些琐事打起来,例如家中只剩下最后一根冰棍而两人都想吃.两个人都想玩儿电脑(可是他们家只有一台电脑)……遇到这种问题,一 ...
- 洛谷 P1505 [国家集训队]旅游 树链剖分
目录 题面 题目链接 题目描述 输入输出格式 输入格式 输出格式 输入输出样例 输入样例: 输出样例: 说明 思路 AC代码 总结 题面 题目链接 P1505 [国家集训队]旅游 题目描述 Ray 乐 ...
- [洛谷P1527] [国家集训队]矩阵乘法
洛谷题目链接:[国家集训队]矩阵乘法 题目背景 原 <补丁VS错误>请前往P2761 题目描述 给你一个N*N的矩阵,不用算矩阵乘法,但是每次询问一个子矩形的第K小数. 输入输出格式 输入 ...
随机推荐
- js中cookie的使用 以及缺点
什么是Cookie Cookie意为“甜饼”,是由W3C组织提出,最早由Netscape社区发展的一种机制.目前Cookie已经成为标准,所有的主流浏览器如IE.Netscape.Firefox. ...
- xBIM 实战04 在WinForm窗体中实现IFC模型的加载与浏览
系列目录 [已更新最新开发文章,点击查看详细] WPF底层使用 DirectX 进行图形渲染.DirectX 能理解可由显卡直接渲染的高层元素,如纹理和渐变,所以 DirectX 效率更高. ...
- BZOJ 3339 线段树
思路: 考虑离线处理 显然 l固定时 r越大 ans越大 那我们不妨按照l从小到大排序 l->l+1的时候 l到next[l]这段区间都跟a[l]取min就好了 搞颗线段树维护一下 //By S ...
- Core Java(一)
一. 绪 1.软件:按照特定顺序组织的计算机数据和指令的集合. 软件开发:借助开发工具与计算机语言制作软件 2.计算机语言:用于人与计算机通讯的语言 分为机器语言,汇编语言,高级语言 高级语言分为编译 ...
- 蛋白质GO信息的一些数据库
最近用到蛋白质序列数据,但是才发现蛋白质的编号主要分为两种:一种是ENSP开头,主要是在ensembl数据库查询asia.ensembl.org/Human/Search:而另一种是uniprot.w ...
- 记一次mysql性能优化过程
摘要: 所谓mysql的优化,三分是配置的优化,七分是sql语句的优化,通过一些案例分析,希望给大家在工作中带来一些思路 由于配置是运行过那么长时间,很稳定,基本上不考虑,所以本次主要是sql的优化, ...
- 关于注意力机制(《Attention is all you need》)
深度学习做NLP的方法,基本上都是先将句子分词,然后每个词转化为对应的词向量序列.(https://kexue.fm/archives/4765) 第一个思路是RNN层,递归进行,但是RNN无法很好地 ...
- yii2.0 发送邮件带word小附件
把 common/config/main-local.php 下的 mailer 注释掉: 'mailer'=>[ 'class ...
- JavaScript系列——数组元素左右移动N位算法实现
引言 在自己刚刚毕业不久的时候,去了一家公司面试,面试官现场考了我这道题,我记忆深刻,当时没有想到思路,毫无疑问被面试官当成菜鸟了.最近刚好在研究数组的各种算法实现,就想到这道题,可以拿来实现一下,纪 ...
- Python求阴影部分面积
一.前言说明 今天看到微信群里一道六年级数学题,如下图,求阴影部分面积 看起来似乎并不是很难,可是博主添加各种辅助线,写各种方法都没出来,不得已而改用写Python代码来求面积了 二.思路介绍 1.用 ...