2653: middle

链接

分析:

  二分答案+主席树。

  对于中位数的经典做法,就是二分一个数,将小于的变成-1,大于等于的变成+1,那么如果sum>=0(因为+1包括等于),L=mid+1,否则R=mid-1。

  那么考虑二分一个中位数(当然只二分出现过的数即可),然后向上面一样判断。

  因为二分的数字只有n个,可以建立n颗只包含-1和+1的权值线段树,发现第i小的权值线段树与第i+1小的权值线段树只有一个位置不同,所以可以类似可持久化的思路,每次只去建立一条链。

  查询的区间有很多个,不能挨个查询它们的和,由于查询最大值,所以可以再在线段树上维护左端最大子段和,右端最大子段和。

代码:

#include<cstdio>
#include<algorithm>
#include<cstring>
#include<iostream>
#include<cmath>
#include<cctype>
#include<set>
#include<queue>
#include<vector>
#include<map>
#define pa pair<int,int>
using namespace std;
typedef long long LL; inline int read() {
int x=,f=;char ch=getchar();for(;!isdigit(ch);ch=getchar())if(ch=='-')f=-;
for(;isdigit(ch);ch=getchar())x=x*+ch-'';return x*f;
} const int N = ;
struct Node{
int sum, Lmx, Rmx;
}T[N * ];
int ls[N * ], rs[N * ], Root[N], Index, n;
pa A[N]; Node operator + (const Node &A,const Node &B) {
Node res;
res.sum = A.sum + B.sum;
res.Lmx = max(A.Lmx, A.sum + B.Lmx);
res.Rmx = max(B.Rmx, A.Rmx + B.sum);
return res;
}
void build(int l,int r,int &rt) {
rt = ++Index;
if (l == r) {
T[rt].sum = T[rt].Lmx = T[rt].Rmx = ; return ;
}
int mid = (l + r) >> ;
build(l, mid, ls[rt]); build(mid + , r, rs[rt]);
T[rt] = T[ls[rt]] + T[rs[rt]];
}
void update(int l,int r,int &rt,int pre,int p) {
if (!rt) rt = ++Index;
if (l == r) {
T[rt].sum = T[rt].Lmx = T[rt].Rmx = -; return ;
}
int mid = (l + r) >> ;
if (p <= mid) {
rs[rt] = rs[pre];
update(l, mid, ls[rt], ls[pre], p);
} else {
ls[rt] = ls[pre];
update(mid + , r, rs[rt], rs[pre], p);
}
T[rt] = T[ls[rt]] + T[rs[rt]];
}
Node query(int l,int r,int rt,int L,int R) {
if (L <= l && r <= R) return T[rt];
int mid = (l + r) >> ;
if (R <= mid) return query(l, mid, ls[rt], L, R);
else if (L > mid) return query(mid + , r, rs[rt], L, R);
else return query(l, mid, ls[rt], L, R) + query(mid + , r, rs[rt], L, R);
}
bool check(int x,int l1,int r1,int l2,int r2) {
Node a, b, c; b.sum = ;
if (l2 > r1 + ) b = query(, n, Root[x], r1 + , l2 - );
a = query(, n, Root[x], l1, r1);
c = query(, n, Root[x], l2, r2);
return (a.Rmx + b.sum + c.Lmx) >= ;
}
int main() {
n = read();
for (int i = ; i <= n; ++i) {
A[i].first = read(), A[i].second = i;
}
sort(A + , A + n + );
build(, n, Root[]);
for (int i = ; i <= n; ++i)
update(, n, Root[i], Root[i - ], A[i - ].second);
int c[], m = read(), ans = , pos;
while (m --) {
for (int i = ; i < ; ++i) c[i] = (read() + ans) % n + ;
sort(c, c + );
int l = , r = n;
while (l <= r) {
int mid = (l + r) >> ;
if (check(mid, c[], c[], c[], c[])) pos = mid, l = mid + ;
else r = mid - ;
}
ans = A[pos].first;
printf("%d\n", ans);
}
return ;
}

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

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

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

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

  4. BZOJ 2653 middle

    AC通道:http://www.lydsy.com/JudgeOnline/problem.php?id=2653 题目大意:多组询问,求左右端点在规定范围内移动所能得到的最大中位数. [分析] 求中 ...

  5. BZOJ 2653: middle 主席树 二分

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

  6. BZOJ 2653 middle | 主席树

    题目: http://www.lydsy.com/JudgeOnline/problem.php?id=2653 题解: 设答案为ans,把大于等于ans的记为1,小于的记为-1,这样可以知道当前an ...

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

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

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

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

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

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

随机推荐

  1. UML建模中简单消息、同步消息和异步消息

    两种消息在UML图中的表示方法如图: 1.同步方式 两个通信应用服务之间必须要进行同步,两个服务之间必须都是正常运行的.发送程序和接收程序都必须一直处于运行状态,并且随时做好相互通信的准备. 发送程序 ...

  2. SQL SERVER Management Studio编写SQL时没有智能提示的解决方式

    1. 检查设置里是否启用智能感知(Intellisence),可以在“工具”→“选项”里设置 2. 如果启用后还是无效,可以新建一个查询窗口查询,输入关键词的前面几个字母看是否有提示(或者使用Ctrl ...

  3. 选中复选框,才能在文本框中输东西。button按钮已启用,

  4. js判断状态

    '<input type="radio" class="danxuan" name="danxuan" code="'||v ...

  5. [翻译] NSRegexTester

    NSRegexTester This is a very simple Mac OS X application that allows you to test regular expressions ...

  6. Jenkins定时构建和轮询SCM设置说明

    看图说事: 一.定时构建:不管SVN或Git中数据有无变化,均执行定时化的构建任务 : 二.轮询SCM:只要SVN或Git中数据有更新,则执行构建任务: 三.构建语法说明: 1.首先格式为:* * * ...

  7. python2.7下同步华为云照片的爬虫程序实现

    1.背景 随着华为手机的销量加大,华为云的捆绑服务使用量也越来越广泛,华为云支持自动同步照片.通讯录.记事本等,用着确实也挺方便的,云服务带来方便的同时,也带来了数据管理风险.华为目前只提供一个www ...

  8. Linux 系统的/var目录

    /var目录主要针对常态性变动的文件,包括缓存(cache).登录档(log file)以及某些软件运作所产生的文件 /var目录下的重要目录 目录 应放置文件内容 /var/cache/ 应用程序本 ...

  9. XGBoost 输出特征重要性以及筛选特征

    1.输出XGBoost特征的重要性 from matplotlib import pyplot pyplot.bar(range(len(model_XGB.feature_importances_) ...

  10. 唯品会RPC服务框架与容器化演进--转

    原文地址:http://mp.weixin.qq.com/s?__biz=MzAwMDU1MTE1OQ==&mid=405781868&idx=1&sn=cbb10d37e25 ...