题意:

左端点在[a,b],右端点在[c,d],求这个线段里中位数(上取整)最大值

思路:

对数组离散化,对每一个值建中位数的可持久化线段树(有重复也没事),就是对于root[i],大于等于i的值为1,小于的为-1,

从小到大插入可持久化线段树即可

如果中位数为m,那么从左端点到右端点[l,r]的序列和应该>=0,我们只需要二分这个m检查是不是序列和>=0即可

满足左端点在[a,b],右端点在[c,d]的子序列和的最大值,就是我们在用线段树维护最大子序和时的

[b+1,c-1]的sum+[a,b]的maxr+[c,d]的maxl

代码:

#include<iostream>
#include<cstdio>
#include<algorithm>
#include<cmath>
#include<cstring>
#include<string>
#include<stack>
#include<queue>
#include<deque>
#include<set>
#include<vector>
#include<map>
#include<functional> #define fst first
#define sc second
#define pb push_back
#define mem(a,b) memset(a,b,sizeof(a))
#define lson l,mid,root<<1
#define rson mid+1,r,root<<1|1
//#define lc root<<1
//#define rc root<<1|1
#define lowbit(x) ((x)&(-x)) using namespace std; typedef double db;
typedef long double ldb;
typedef long long ll;
typedef unsigned long long ull;
typedef pair<int,int> PI;
typedef pair<ll,ll> PLL; const db eps = 1e-;
const int mod = 1e9+;
const int maxn = 2e5+;
const int maxm = 2e6+;
const int inf = 0x3f3f3f3f;
const db pi = acos(-1.0); int n;
PI a[maxn];
int q;
vector<ll>v;
int getid(ll x){
return lower_bound(v.begin(), v.end(), x)-v.begin()+;
}
bool cmp(PI a, PI b){
if(a.fst==b.fst)return a.sc<b.sc;
return a.fst<b.fst;
}
int root[maxn];
struct Node{
int maxl,maxr;
int sum;
}node[maxn*];
int ls[maxn],rs[maxn];
int tot,totn;
void build(int l, int r, int &root){
root = ++tot;
int mid = (l+r)>>;
if(l==r){
node[root].maxl=node[root].maxr=node[root].sum=;
return;
}
build(l, mid, ls[root]);
build(mid+, r, rs[root]);
node[root].maxl=max(node[ls[root]].sum+node[rs[root]].maxl, node[ls[root]].maxl);
node[root].maxr=max(node[rs[root]].sum+node[ls[root]].maxr, node[rs[root]].maxr);
node[root].sum=node[ls[root]].sum+node[rs[root]].sum;
return;
}
void insert(int lst, int &now, int l, int r, int p){
now = ++tot;
ls[now]=ls[lst];
rs[now]=rs[lst];
node[now] = node[lst];
int mid = (l+r)>>;
if(l==r){
node[now].maxl=node[now].maxr=node[now].sum=-;
return;
}
if(p<=mid)insert(ls[lst], ls[now], l, mid, p);
else insert(rs[lst], rs[now], mid+, r, p);
node[now].maxl=max(node[ls[now]].sum+node[rs[now]].maxl, node[ls[now]].maxl);
node[now].maxr=max(node[rs[now]].sum+node[ls[now]].maxr, node[rs[now]].maxr);
node[now].sum=node[ls[now]].sum+node[rs[now]].sum;
}
Node query(int ql, int qr, int l, int r, int now){ int mid = (l+r)>>;
if(l==ql&&r==qr){
return node[now];
}
else if(mid>=qr){
return query(ql, qr, l, mid, ls[now]);
}
else if(mid<ql){
return query(ql, qr, mid+, r, rs[now]);
}
else{
Node ans;
Node lc=query(ql,mid,l,r,now);
Node rc=query(mid+,qr,l,r,now);
ans.sum=lc.sum+rc.sum;
ans.maxl=max(lc.sum+rc.maxl,lc.maxl);
ans.maxr=max(rc.sum+lc.maxr,rc.maxr);
return ans;
}
}
void dfs(int x){
printf("%d %d %d %d %d %d\n",x,ls[x],rs[x],node[x].sum,node[x].maxl,node[x].maxr);
if(ls[x])dfs(ls[x]);
if(rs[x])dfs(rs[x]);
}
int main() {
scanf("%d", &n);
for(int i = ; i <= n; i++){
scanf("%d" ,&a[i].fst);
a[i].sc=i;
v.pb(a[i].fst);
}
sort(v.begin(), v.end());
v.erase(unique(v.begin(),v.end()),v.end());
totn=v.size();
int lstans = ;
int tmp[];
sort(a+,a++n,cmp);
build(,n,root[]);
for(int i = ; i <= n; i++){
insert(root[i-],root[i],,n,a[i].sc);
}int q;
//dfs(root[4]);
scanf("%d", &q);
while(q--){
for(int i = ; i <= ; i++){
scanf("%d", &tmp[i]);
tmp[i]=(tmp[i]+lstans)%n;
}
sort(tmp+,tmp++);
int l = ;
int r = n+;
int ans = ; while(l<=r){
int mid = (l+r)>>;
int res=max(query(tmp[]+,tmp[]+-,,n,root[mid-]).maxr,);
res+=query(tmp[]+,tmp[]+,,n,root[mid-]).sum;
res+=max(query(tmp[]++,tmp[]+,,n,root[mid-]).maxl,);
if(res>=){
ans=mid;
l=mid+;
}
else r = mid-;
}
printf("%d\n",lstans=v[ans-]);
}
return ;
}
/*
5
2 4 1 5 3
3
3 1 0 2
2 3 1 4
3 1 4 0 5
170337785
271451044
22430280
969056313
206452321
3
3 1 0 2
2 3 1 4
3 1 4 0
*/

BZOJ 2653 middle (可持久化线段树+中位数+线段树维护最大子序和)的更多相关文章

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

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

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

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

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

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

  4. bzoj 2653 middle (可持久化线段树)

    middle Time Limit: 20 Sec  Memory Limit: 512 MBSubmit: 1981  Solved: 1097[Submit][Status][Discuss] D ...

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

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

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

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

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

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

  8. BZOJ 2653: middle 主席树 二分

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

  9. bzoj 2653 middle(主席树)

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

随机推荐

  1. Java 中级 学习笔记 1 JVM的理解以及新生代GC处理流程

    写在最前 从毕业到现在已经过去了差不多一年的时间,工作还算顺利,但总是离不开CRUD ,我觉得这样下去肯定是不行的,温水煮青蛙,势必有一天,会昏昏沉沉的迷失在温水里.所以,需要将之前学习JAVA 当中 ...

  2. JWT(二):使用 Java 实现 JWT

    JWT(一):认识 JSON WebToken JWT(二):使用 Java 实现 JWT 介绍 原理在上篇<JWT(一):认识 JSON Web Token>已经说过了,实现起来并不难, ...

  3. [转载] Windows系统批处理延迟方法

    小贴士:方法四 亲测有效,因为当时对于精确度要求不是很高,所以没有具体测试它的精确度.其他方法没有测过,用到的时候再测吧! 批处理延时启动的几个方法 方法一:ping 缺点:时间精度为1秒,不够精确 ...

  4. Spring Boot2 系列教程(十九) | @Value 和 @ConfigurationProperties 的区别

    微信公众号:一个优秀的废人.如有问题,请后台留言,反正我也不会听. 前言 最近有跳槽的想法,所以故意复习了下 SpringBoot 的相关知识,复习得比较细.其中有些,我感觉是以前忽略掉的东西,比如 ...

  5. C++类中的重载

    函数重载回顾 函数重载的本质为相互独立的不同函数 C++中通过函数名和函数参数确定函数调用 无法直接通过函数名得到重载函数的入口地址 函数重载必然发生在同一个作用域 类中的成员函数可以进行重载 构造函 ...

  6. CDQ 入门

    推荐博客 :https://blog.csdn.net/wu_tongtong/article/details/78785836 https://www.cnblogs.com/mlystdcall/ ...

  7. 死磕面试 - Dubbo基础知识37问(必须掌握)

    作为一个JAVA工程师,出去项目拿20k薪资以上,dubbo绝对是面试必问的,即使你对dubbo在项目架构上的作用不了解,但dubbo的基础知识也必须掌握. 整理分享一些面试中常会被问到的dubbo基 ...

  8. [apue] 一个查看当前终端标志位设置的小工具

    话不多说,先看运行效果: >./term input flag 0x00000500 BRKINT not in ICRNL IGNBRK not in IGNCR not in IGNPAR ...

  9. git 工作中实用 多人协同开发

    多人协同开发 .克隆分支 git clone -b dev1. url .创建并关联远程分支 git checkout -b dev_wt origin/dev_wt 情况一获取其它分支的代码,并合并 ...

  10. restframework 认证、权限、频率组件

    一.认证 1.表的关系 class User(models.Model): name = models.CharField(max_length=32) pwd = models.CharField( ...