题意:有一篇博客。一共有n个人,心中有他们期望该博客得到的赞数a[i]。当某个时刻该博客的获赞数<a[i],则该人会使得赞数+1,当赞数>a[i],该人会使得赞数-1,当赞数=a[i],不做任何改变。

对于1<=k<=n,询问1~k个人按一定的顺序给该博客从0开始点赞或点踩,该博客的最大获赞数。

-1e5<=a[i]<=1e5,n<=1e5。

标程:

 #include<bits/stdc++.h>
#define mid ((l+r)>>1)
using namespace std;
const int N=;
const int inf=0x3f3f3f3f;
int tag1[N<<],tag2[N<<],Max[N<<],Min[N<<],n,ax; void build1(int k,int l,int r)
{
if (l==r) {Max[k]=l;return;}
build1(k<<,l,mid);build1(k<<|,mid+,r);
Max[k]=max(Max[k<<],Max[k<<|]);
}
void build2(int k,int l,int r)
{
if (l==r) {Min[k]=l;return;}
build2(k<<,l,mid);build2(k<<|,mid+,r);
Min[k]=min(Min[k<<],Min[k<<|]);
}
void down1(int k)
{
if (tag1[k])
{
tag1[k<<]+=tag1[k],tag1[k<<|]+=tag1[k];
Max[k<<]+=tag1[k],Max[k<<|]+=tag1[k];
tag1[k]=;
}
}
void down2(int k)
{
if (tag2[k])
{
tag2[k<<]+=tag2[k],tag2[k<<|]+=tag2[k];
Min[k<<]+=tag2[k],Min[k<<|]+=tag2[k];
tag2[k]=;
}
}
void add1(int k,int l,int r,int x)
{
if (x<=l) {tag1[k]++;Max[k]++;return;}
down1(k);
if (x<=mid) add1(k<<,l,mid,x);
add1(k<<|,mid+,r,x);
Max[k]=max(Max[k<<],Max[k<<|]);
}
void add2(int k,int l,int r,int x)
{
if (r<=x) {tag2[k]++;Min[k]++;return;}
down2(k);
if (x>mid) add2(k<<|,mid+,r,x);
add2(k<<,l,mid,x);
Min[k]=min(Min[k<<],Min[k<<|]);
}
int qry1(int k,int l,int r)//找到恰好为0的位置
{
if (l==r) return l;
down1(k);
if (Max[k<<]>=) return qry1(k<<,l,mid);
else return qry1(k<<|,mid+,r);
}
int qry2(int k,int l,int r,int x)
{
if (x<=l) return Min[k];
down2(k); int res=inf;
if (x<=mid) res=min(res,qry2(k<<,l,mid,x));
res=min(res,qry2(k<<|,mid+,r,x));
return res;
}
int main()
{
build1(,-N,);
build2(,-N,N);
scanf("%d",&n);
for (int i=;i<=n;i++)
{
scanf("%d",&ax);
if (ax<) add1(,-N,,ax);
add2(,-N,N,ax-);
int l=qry1(,-N,);
printf("%d\n",qry2(,-N,N,l));
}
return ;
}

易错点:1.add1前缀++时,最后一个位置是不加的,所以应该从ax-1开始。

题解:线段树优化dp展开

发现一定是升序过来给赞是最优的,而这样一定存在一个分界点,该点之前x--,该点之后x单调不减。具体地,当a[x]<=-x时,x=x-1。我们设a[x]=-x的点为分界点。

之后的单调不减怎么求答案?设f[i]为第i个人点赞后,该博客的获赞数。f[i]=min(f[i-1]+1,a[i])。

展开:设分界点为x,分界点右边的第一个人为第l个,右端点为r,则f[r]=min(x+(r-l+1),a[l]+r-l,...,a[r-1]+1,a[r])。也可以用线段树优化掉。

开两棵权值线段树,一棵用来寻找分界点,维护a[x]+x的值,插入时后缀区间+1,查询时求a[x]=x的点。一棵用来维护f数组,插入时前缀区间+1(不包括右端点),查询时求后缀最小值。

不管是否实际加入元素,权值线段树的区间都是整体加,因为有单调性不会冲突。

CF773E Blog Post Rating的更多相关文章

  1. Blog Post Rating CodeForces - 806E (线段树二分)

    题目链接 题目大意: 有一个博客, 初始分数为$0$, 有$n$个人, 第$i$个人有一个期望值$a_i$, 如果第$i$个人浏览博客时,博客赞数高于$a_i$博客分数$-1$, 低于$+1$, 相等 ...

  2. EF6 DataMigration 从入门到进阶

    引言 在EntityFramework的开发过程中我们有时因需求变化或者数据结构设计的变化经常会改动表结构.但数据库Schema发生变化时EF会要求我们做DataMigration 和UpdateDa ...

  3. Ef core 如何设置主键

    在正题之前,先说明几个问题. (1)写 sql 不好吗,为什么要引入 ORM ? 总的来说由于需求的复杂性增加,引入了面向对象编程,进而有了 ORM ,ORM 使得开发人员以对象的方式表达业务逻辑.对 ...

  4. HDU 4870 Rating(高斯消元 )

    HDU 4870   Rating 这是前几天多校的题目,高了好久突然听旁边的大神推出来说是可以用高斯消元,一直喊着赶快敲模板,对于从来没有接触过高斯消元的我来说根本就是一头雾水,无赖之下这几天做DP ...

  5. SharePoint中Rating相关的字段。

      From: https://sharepoint.stackexchange.com/questions/194197/how-to-manipulate-likeby-nooflikes-rat ...

  6. 日向blog开发记录

    一点历史关于,Sonne Blog 2016.03.25springmvc + hibernate框架搭建.2016.04.21日向blog首页.2016.04.24分页实现.2016.04.30登录 ...

  7. blog (后续更新)

    设计Model(设计数据库) from django.db import models # Create your models here. class BlogsPost(models.Model) ...

  8. tensorflow 一些好的blog链接和tensorflow gpu版本安装

    pading :SAME,VALID 区别  http://blog.csdn.net/mao_xiao_feng/article/details/53444333 tensorflow实现的各种算法 ...

  9. http://blog.csdn.net/java2000_wl/article/details/8627874

    http://blog.csdn.net/java2000_wl/article/details/8627874

随机推荐

  1. Alice's Classified Message HDU - 5558 后缀自动机求某个后缀出现的最早位置

    题意: 给定一个长度不超过 10W 的只包含小写字母的字符串,从下标 0 到 n−1.从下标 0 开始操作, 每次对于下标 pos查找下标 pos 开始的子串中最长的在其他地方出现过的长度,其他出现的 ...

  2. unix, PF_UNIX, AF_UNIX, PF_LOCAL, AF_LOCAL - 用于本地内部进程通讯的套接字。

    SYNOPSIS(总览) #include <sys/socket.h> #include <sys/un.h> unix_socket = socket(PF_UNIX, t ...

  3. vue axios----基于 Promise 的 HTTP 请求

    vue axiosvue2.0之axios接口請求管理功能特性axios API開始使用get請求post请求多个请求并发拦截器移除一个拦截器:自定义的 axios 实例添加拦截器:vue2.0之ax ...

  4. 深度探索C++对象模型读书笔记-第六章执行期语意学

    在函数中,编译器会帮助将析构函数(Destructor) 安插在相应的位置.对于函数中的局部对象,会将析构函数安插在对象的每一个离开点. 例如: 1: void Function(int a) { 2 ...

  5. 使用js 判断当前运行环境实在浏览器还是在手机

    转: 在跨平台,各种浏览器,移动设备兼容的时候,经常要根据设备.浏览器做特定调整,所以判断设备和浏览器的工作,经常会用到,这里做一下总结. 有关浏览器类型的信息都藏在USER-AGENT里面,首先读取 ...

  6. Oracle 、MySql 数据库表被锁的原因分析

    记录一次准备给客户预演示出现的问题 事故的背景: 当所以功能开发完成后,开发人员在本地进行了测视已经没问题了.就把所有开发的功能模块合并到 dev 分支,进行打包,发布到预演示的线上环境.当在给相关人 ...

  7. bzoj1012题解

    [解题思路] 强制在线线段树/树状数组,没什么好说的..复杂度O(mlog2m)(线段树)或O(mlog22m)(树状数组). [参考代码] (还naive的时候写的zkw真是翔..) #includ ...

  8. NOIp2018集训test-9-5(am)

    Problem A. maze 递归处理,题解写得真简单. 我大概这辈子也写不出来这种东西吧. Problem B. count 容易发现合法的数中一定有且仅有两个数加起来等于10,其他数两两配对加起 ...

  9. NX二次开发-UFUN圆弧矩阵标记、起始角和结束角(弧度测量)、圆弧中心坐标和圆弧半径UF_CURVE_ask_arc_data(边可以用)

    1 NX11+VS2013 2 3 #include <uf.h> 4 #include <uf_ui.h> 5 #include <uf_modl.h> 6 #i ...

  10. SSDT

    2.系统服务调度表SSDT及SSSDT Shadow 系统服务:由操作系统提供的一组函数(内核函数),API可以间接或者直接的调用系统服务.操作系统以动态链接库(DLL)的形式提供API. SSDT: ...