题目:

http://www.lydsy.com/JudgeOnline/problem.php?id=2653


题解:

设答案为ans,把大于等于ans的记为1,小于的记为-1,这样可以知道当前ans是大了还是小了

然后二分答案,就是求最大子段和的问题,根据网上的题解:[b,c]是必选的,然后选[a,b]和[c,d]的最大字段和就行了

#include<cstdio>
#include<cstring>
#include<algorithm>
#define N 20010
using namespace std;
int sz,q,root[N],ls[N*],rs[N*],sum[N*],lm[N*],rm[N*],n,m,b[],lastans;
struct node
{
int p,v;
}a[N];
bool cmp(node a,node b)
{
return a.v<b.v;
}
void update(int k)
{
sum[k]=sum[ls[k]]+sum[rs[k]];
lm[k]=max(lm[ls[k]],sum[ls[k]]+lm[rs[k]]);
rm[k]=max(rm[rs[k]],sum[rs[k]]+rm[ls[k]]);
}
void build(int &rt,int l,int r)
{
rt=++sz;
int mid=l+r>>;
if (l==r)
{
sum[rt]=lm[rt]=rm[rt]=;
return;
}
build(ls[rt],l,mid);
build(rs[rt],mid+,r);
update(rt);
}
void insert(int x,int l,int r,int &y,int p,int v)
{
y=++sz;
ls[y]=ls[x];
rs[y]=rs[x];
if (l==r)
{
sum[y]=lm[y]=rm[y]=v;
return;
}
int mid=(l+r)>>;
if (p<=mid) insert(ls[x],l,mid,ls[y],p,v);
else insert(rs[x],mid+,r,rs[y],p,v);
update(y);
}
int que1(int k,int l,int r,int ll,int rr)
{
if (ll==l&&r==rr) return sum[k];
int mid=(l+r)>>;
if (rr<=mid) return que1(ls[k],l,mid,ll,rr);
else if (ll>mid) return que1(rs[k],mid+,r,ll,rr);
else return que1(ls[k],l,mid,ll,mid)+que1(rs[k],mid+,r,mid+,rr);
}
int que2(int k,int l,int r,int ll,int rr)
{
if (ll==l&&r==rr) return rm[k];
int mid=(l+r)>>;
if (rr<=mid) return que2(ls[k],l,mid,ll,rr);
else if (ll>mid) return que2(rs[k],mid+,r,ll,rr);
else return max(que2(rs[k],mid+,r,mid+,rr),que1(rs[k],mid+,r,mid+,rr)+que2(ls[k],l,mid,ll,mid));
}
int que3(int k,int l,int r,int ll,int rr)
{
if (ll==l&&r==rr) return lm[k];
int mid=(l+r)>>;
if (rr<=mid) return que3(ls[k],l,mid,ll,rr);
else if (ll>mid) return que3(rs[k],mid+,r,ll,rr);
else return max(que3(ls[k],l,mid,ll,mid),que1(ls[k],l,mid,ll,mid)+que3(rs[k],mid+,r,mid+,rr));
}
bool judge(int k,int a,int b,int c,int d)
{
int temp();
if (c->b) temp+=que1(root[k],,n-,b+,c-);
temp+=que2(root[k],,n-,a,b);
temp+=que3(root[k],,n-,c,d);
return temp>=;
}
int main()
{
scanf("%d",&n);
for (int i=; i<n; i++)
{
scanf("%d",&a[i].v);
a[i].p=i;
}
sort(a,a+n,cmp);
build(root[],,n-);
for (int i=; i<n; i++)insert(root[i-],,n-,root[i],a[i-].p,-);
scanf("%d",&q);
for (int i=; i<=q; i++)
{
scanf("%d%d%d%d",&b[],&b[],&b[],&b[]);
for (int j=; j<; j++) b[j]=(b[j]+lastans)%n;
sort(b,b+);
int l=,r=n-,x;
while (l<=r)
{
int mid=(l+r)>>;
if (judge(mid,b[],b[],b[],b[])) x=mid,l=mid+;
else r=mid-;
}
lastans=a[x].v;
printf("%d\n",lastans);
}
}

BZOJ 2653 middle | 主席树的更多相关文章

  1. bzoj 2653: middle (主席树+二分)

    2653: middle Time Limit: 20 Sec  Memory Limit: 512 MBSubmit: 2522  Solved: 1434[Submit][Status][Disc ...

  2. bzoj 2653 middle(主席树)

    题面:https://vjudge.net/problem/HYSBZ-2653 博客:https://blog.csdn.net/litble/article/details/78984846 这个 ...

  3. BZOJ 2653: middle(主席树+二分答案)

    传送门 解题思路 首先可以想到一种暴力做法,就是询问时二分,然后大于等于这个值的设为1,否则设为-1,然后就和GSS1那样统计答案.但是发现这样时间空间复杂度都很爆炸,所以考虑预处理,可以用主席树来做 ...

  4. BZOJ 2653: middle 主席树 二分

    https://www.lydsy.com/JudgeOnline/problem.php?id=2653 因为是两个方向向外延伸所以不能对编号取前缀和(这里只有前缀和向后传递的性质,不是实际意义的和 ...

  5. BZOJ 2653: middle [主席树 中位数]

    传送门 题意: 一个长度为n的序列a,设其排过序之后为b,其中位数定义为b[n/2],其中a,b从0开始标号,除法取下整.给你一个 长度为n的序列s.回答Q个这样的询问:s的左端点在[a,b]之间,右 ...

  6. [BZOJ 2653] middle(可持久化线段树+二分答案)

    [BZOJ 2653] middle(可持久化线段树+二分答案) 题面 一个长度为n的序列a,设其排过序之后为b,其中位数定义为b[n/2],其中a,b从0开始标号,除法取下整. 给你一个长度为n的序 ...

  7. bzoj 2653 middle 二分答案 主席树判定

    判断中位数是否可行需要将当前的解作为分界,大于其的置为1,小于为-1,然后b-c必选,ab,cd可不选,这个用线段树判定就好 但不能每次跑,所以套主席树,按权值排序,构建主席树,更新时将上一个节点改为 ...

  8. BZOJ 2653 middle 二分答案+可持久化线段树

    题目大意:有一个序列,包含多次询问.询问区间左右端点在规定区间里移动所得到的最大中位数的值. 考虑对于每个询问,如何得到最优区间?枚举显然是超时的,只能考虑二分. 中位数的定义是在一个序列中,比中位数 ...

  9. [BZOJ2653]middle 主席树+二分

    2653: middle Time Limit: 20 Sec  Memory Limit: 512 MBSubmit: 2042  Solved: 1123[Submit][Status][Disc ...

随机推荐

  1. 利用deadline_timer实现定时器Timer

    // 类似QTimer的定时器 class Timer { typedef void(* handler)(); public: Timer() : m_millseconds() , m_timer ...

  2. 3.2.5 Magic Squares 魔板

    3.2.5 Magic Squares 魔板 成功地发明了魔方之后,鲁比克先生发明了它的二维版本,称作魔板.这是一张有8个大小相同的格子的魔板: 1 2 3 4 8 7 6 5 我们知道魔板的每一个方 ...

  3. Java分享笔记:泛型机制的程序演示

    package packA; import java.util.*; public class GenericDemo { public static void main(String[] args) ...

  4. Java OOP——第七章 多线程

    1.进程:是指运行中的应用程序,每个进程都有自己独立的地址空间(内存空间): Eg:用户点击桌面的IE浏览器,就启动了一个进程,操作系统就会为该进程分配独立的地址空间.当用户再次点击左面的IE浏览器, ...

  5. (转)Unity 和 Cocos2d-x 越渐流行,国内公司开发「自研游戏引擎」的意义何在?

    分几个角度来说:一.我认为,Unity3D将无可挽回的,或者说,势在必得的,成为接下来很多年内,世界移动领域游戏引擎市场霸主.回顾历史,正如同咱们经历过一次又一次的互联网时代变革一样,x86,wind ...

  6. 4.1 基本类型和引用类型的值【JavaScript高级程序设计第三版】

    ECMAScript 变量可能包含两种不同数据类型的值:基本类型值和引用类型值.基本类型值指的是简单的数据段,而引用类型值指那些可能由多个值构成的对象. 在将一个值赋给变量时,解析器必须确定这个值是基 ...

  7. JZOJ 5906. 传送门

    Description             8102年,Normalgod在GLaDOS的帮助下,研制出了传送枪.但GLaDOS想把传送枪据为己有,于是把Normalgod扔进了一间实验室.这间实 ...

  8. 深度CNN

    [具体参考可以看这里(https://cloud.tencent.com/developer/article/1369425)

  9. 对文件 I/O,标准 I/O 的缓冲的理解

    1.标准I/O缓冲区 要理解标准I/O,就要先知道文件I/O的业务逻辑. 下面图示为文件I/O 如执行下面的代码: write(fd, buf2, sizeof(buf2)); 图中 buf:就是bu ...

  10. SVD在推荐系统中的应用详解以及算法推导

    SVD在推荐系统中的应用详解以及算法推导     出处http://blog.csdn.net/zhongkejingwang/article/details/43083603 前面文章SVD原理及推 ...