Blog Post Rating CodeForces - 806E (线段树二分)
题目大意: 有一个博客, 初始分数为$0$, 有$n$个人, 第$i$个人有一个期望值$a_i$,
如果第$i$个人浏览博客时,博客赞数高于$a_i$博客分数$-1$, 低于$+1$, 相等不变,
对于每个$i$, 求出$[1,i]$的人按任意顺序浏览博客后最大分数.
题解:
首先, 用贪心可以知道所有人按期望升序排列, 最后得分一定最大
由于期望有负数, 博客分数一定是先减后增的, 然后对这两段分类讨论
对于递减的段, 最后分数为递增递减的临界值
假设临界值为$x$, 设比$x$小的数的个数为$cnt_x$
可以发现$x$是第一个满足 $cnt_x+x>=0$ 的$x$
比方说排序后序列为$-10,-10,-10,-6,-2,-1$ 那么$x$就为$-4$
权值线段树上二分即可求出$x$ (初值设为$x$, 转为二分第一个$>=0$的数)
在考虑递增区间, 假设当前一共有$r$个数
有转移方程 $f_i=min(a_i,f_{i-1}+1),$ $f$为得分, $a$为排序后数组
可以得到$f_r=min(a_r,a_{r-1}+1,a_{r-2}+2,...,a_{l}+r-l,x+(r-x))$, $a_{l}$为第一个比$x$大的数
用权值线段树维护最小值即可
#include <iostream>
#include <algorithm>
#include <cstdio>
#define REP(i,a,n) for(int i=a;i<=n;++i)
#define mid ((l+r)>>1)
#define lc (o<<1)
#define rc (lc|1)
#define ls lc,l,mid
#define rs rc,mid+1,r
using namespace std; const int N = 5e5+, INF = 0x3f3f3f3f; int n, m, ans;
struct _ {
int mx,tag;
void upd(int x) {
mx+=x,tag+=x;
}
} v1[N<<], v2[N<<]; //v1维护的递减区间
//v2维护递增区间 void pd(_ *v, int o) {
if (v[o].tag) {
v[lc].upd(v[o].tag);
v[rc].upd(v[o].tag);
v[o].tag=;
}
} void add1(int o, int l, int r, int ql, int qr) {
if (ql<=l&&r<=qr) return v1[o].upd();
pd(v1,o);
if (mid>=ql) add1(ls,ql,qr);
if (mid<qr) add1(rs,ql,qr);
v1[o].mx=max(v1[lc].mx,v1[rc].mx);
} void add2(int o, int l, int r, int ql, int qr) {
if (ql<=l&&r<=qr) return v2[o].upd();
pd(v2,o);
if (mid>=ql) add2(ls,ql,qr);
if (mid<qr) add2(rs,ql,qr);
v2[o].mx=min(v2[lc].mx,v2[rc].mx);
} int qry1(int o, int l, int r) {
if (l==r) return l;
pd(v1,o);
if (v1[lc].mx>=) return qry1(ls);
return qry1(rs);
} void qry2(int o, int l, int r, int ql, int qr) {
if (v2[o].mx>=ans) return;
if (ql<=l&&r<=qr) return ans=min(ans,v2[o].mx),void();
pd(v2,o);
if (mid>=ql) qry2(ls,ql,qr);
if (mid<qr) qry2(rs,ql,qr);
} void build1(int o, int l, int r) {
if (l==r) return v1[o].mx=l,void();
build1(ls),build1(rs);
v1[o].mx=max(v1[lc].mx,v1[rc].mx);
} void build2(int o, int l, int r) {
if (l==r) return v2[o].mx=l,void();
build2(ls),build2(rs);
v2[o].mx=min(v2[lc].mx,v2[rc].mx);
} int main() {
scanf("%d", &n);
build1(,-N,);
build2(,-N,N);
REP(i,,n) {
int k;
scanf("%d", &k);
if (k<) add1(,-N,,k,N);
add2(,-N,N,-N,k-);
int x = qry1(,-N,);
ans = INF, qry2(,-N,N,x,N);
printf("%d\n", ans);
}
}
Blog Post Rating CodeForces - 806E (线段树二分)的更多相关文章
- Bash and a Tough Math Puzzle CodeForces - 914D (线段树二分)
大意:给定序列, 单点修改, 区间询问$[l,r]$内修改至多一个数后$gcd$能否为$x$ 这题比较有意思了, 要注意到询问等价于$[l,r]$内最多有1个数不为$x$的倍数 可以用线段树维护gcd ...
- Nastya and King-Shamans CodeForces - 992E (线段树二分)
大意: 给定序列a, 单点更新, 询问是否存在a[i]等于s[i-1], s为a的前缀和, a非负 考虑到前缀和的单调性, 枚举从1开始前缀和, 找到第一个大于等于s[1]的a[i], 如果相等直接输 ...
- Codeforces Gym 100803G Flipping Parentheses 线段树+二分
Flipping Parentheses 题目连接: http://codeforces.com/gym/100803/attachments Description A string consist ...
- Codeforces Gym 100231B Intervals 线段树+二分+贪心
Intervals 题目连接: http://codeforces.com/gym/100231/attachments Description 给你n个区间,告诉你每个区间内都有ci个数 然后你需要 ...
- Educational Codeforces Round 64 (Rated for Div. 2) (线段树二分)
题目:http://codeforces.com/contest/1156/problem/E 题意:给你1-n n个数,然后求有多少个区间[l,r] 满足 a[l]+a[r]=max([l, ...
- hdu4614 线段树+二分 插花
Alice is so popular that she can receive many flowers everyday. She has N vases numbered from 0 to N ...
- 洛谷P4344 脑洞治疗仪 [SHOI2015] 线段树+二分答案/分块
!!!一道巨恶心的数据结构题,做完当场爆炸:) 首先,如果你用位运算的时候不小心<<打成>>了,你就可以像我一样陷入疯狂的死循环改半个小时 然后,如果你改出来之后忘记把陷入死循 ...
- luogu4422 [COCI2017-2018#1] Deda[线段树二分]
讨论帖:线段树二分的题..我还考场切过..白学 这题我一年前的模拟赛考场还切过,现在就不会了..好菜啊. 显然直接线段树拆成$\log n$个区间,然后每个区间在进行线段树二分即可. UPD:复杂度分 ...
- Bash and a Tough Math Puzzle CodeForces 914D 线段树+gcd数论
Bash and a Tough Math Puzzle CodeForces 914D 线段树+gcd数论 题意 给你一段数,然后小明去猜某一区间内的gcd,这里不一定是准确值,如果在这个区间内改变 ...
随机推荐
- linux测试带宽命令,Linux服务器网络带宽测试iperf
linux测试带宽命令,Linux服务器网络带宽测试iperf必须先运行iperf serveriperf -s -i 2客户端iperf -c 服务端IP地址 iperf原理解析 iperf工具可以 ...
- 浅谈CORS
浅谈CORS CORS全称"跨站资源共享"(Cross-Origin Resource Sharing),它允许浏览器克服浏览器同源策略向跨域服务器发出请求. 同源策略 概念 说到 ...
- web前端----html表单操作
form表单 功能:表单用于向服务器传输数据,从而实现用户与Web服务器的交互 表单能够包含input系列标签,比如文本字段.复选框.单选框.提交按钮等等. 表单还可以包含textarea.selec ...
- Mysql利用存储过程插入500W条数据
比如插入1000W数据,不建议一次性插入,比如一次插入500W,分批插入. 创建表 /*部门表*/ CREATE TABLE dept( id INT UNSIGNED PRIMARY KEY AUT ...
- python集合set{ }、集合函数及集合的交、差、并
通过大括号括起来,用逗号分隔元素,特点 1.由不同元素组成,如果定义时存在相同元素,处理时会自动去重 2.无序 3.元素只能是不可变类型,即数字.字符串.布尔和元组,但集合本身可变 4.可直接定义集合 ...
- SP211 PRIMIT - Primitivus recurencis(欧拉回路)
SP211 PRIMIT - Primitivus recurencis 欧拉回路 Warning: enormous Input/Output data 警告:巨大的输入/输出 经过若干(11)次提 ...
- 企业应用开发中最常用c++库
log4cpp,http://log4cpp.sourceforge.net/,跟log4j一样,不说最重要,绝对是最常用的. zk 客户端,https://blog.csdn.net/yangzhe ...
- ssh连接linux服务器不断开- "Write failed: Broken pipe"
我自己用阿里云的服务器的时候,发现ssh连上以后,一会不用就断掉了,非常不方便,服务端的系统是ubuntu. 查了些东西,原来可以去配置服务端的sshd,或者客户端的ssh,就行了. 1,配置服务器端 ...
- 20145317彭垚《网络对抗》Exp9 Web安全基础实践
20145317彭垚<网络对抗>Exp9 Web安全基础实践 基础问题回答 SQL注入攻击原理,如何防御? SQL注入攻击就是通过把SQL命令插入到Web表单递交或输入域名或页面请求的查询 ...
- HDU 2841 Visible Trees(容斥)题解
题意:有一块(1,1)到(m,n)的地,从(0,0)看能看到几块(如果两块地到看的地方三点一线,后面的地都看不到). 思路:一开始是想不到容斥...后来发现被遮住的地都有一个特点,若(a,b)有gcd ...