BZOJ 4826: [Hnoi2017]影魔 单调栈+可持久化线段树
Description
Input
Output
#include <cstring>
#include <cstdio>
#include <stack>
#include <string>
#include <vector>
#include <algorithm>
#define N 200005
#define ll long long
using namespace std;
void setIO(string s) {
string in=s+".in";
string out=s+".out";
freopen(in.c_str(),"r",stdin);
// freopen(out.c_str(),"w",stdout);
}
int n,m,tp,edges;
int p1,p2;
int val[N];
int sta[N];
int L[N],R[N];
int hd[N];
int tot;
int rtl[N];
int rtr[N];
struct Edge {
int x;
int l;
int r;
int v;
int nex;
}e[N*3];
struct node {
int ls;
int rs;
ll tag;
ll sum;
}t[N*80];
void add(int u,int l,int r,int v) {
e[++edges].nex=hd[u];
hd[u]=edges;
e[edges].l=l;
e[edges].r=r;
e[edges].x=u;
e[edges].v=v;
}
int newnode() {
return ++tot;
}
int update(int x,int l,int r,int L,int R,int v) {
if(L>R) {
return x;
}
int now=newnode();
t[now]=t[x];
t[now].sum+=(ll)(min(r,R)-max(l,L)+1)*v;
if(l>=L&&r<=R) {
t[now].tag+=v;
return now;
}
int mid=(l+r)>>1;
if(L<=mid) {
t[now].ls=update(t[x].ls,l,mid,L,R,v);
}
if(R>mid) {
t[now].rs=update(t[x].rs,mid+1,r,L,R,v);
}
return now;
}
ll query(int x,int l,int r,int L,int R) {
if(!x) {
return 0;
}
if(l>=L&&r<=R) {
return t[x].sum;
}
int mid=(l+r)>>1;
ll re=(ll)t[x].tag*(min(r,R)-max(l,L)+1);
if(L<=mid) {
re+=query(t[x].ls,l,mid,L,R);
}
if(R>mid) {
re+=query(t[x].rs,mid+1,r,L,R);
}
return re;
}
int main() {
// setIO("input");
int i,j;
scanf("%d%d%d%d",&n,&m,&p1,&p2);
for(i=1;i<=n;++i) {
scanf("%d",&val[i]);
}
for(i=1;i<=n;++i) {
while(tp&&val[sta[tp]]<val[i]) {
--tp;
}
L[i]=sta[tp];
sta[++tp]=i;
}
sta[tp=0]=n+1;
for(i=n;i>=1;--i) {
while(tp&&val[sta[tp]]<val[i]) {
--tp;
}
R[i]=sta[tp];
sta[++tp]=i;
}
for(i=1;i<=n;++i) {
add(L[i],R[i],R[i],p1);
add(L[i],i+1,R[i]-1,p2);
add(R[i],L[i]+1,i-1,p2);
}
// 向右
for(i=1;i<=n;++i) {
rtl[i]=rtl[i-1];
for(j=hd[i];j;j=e[j].nex) {
if(e[j].l>i) {
rtl[i]=update(rtl[i],1,n,max(1,e[j].l),min(n,e[j].r),e[j].v);
}
}
if(i!=n) {
rtl[i]=update(rtl[i],1,n,i+1,i+1,p1);
}
}
for(i=n;i>=1;--i) {
rtr[i]=rtr[i+1];
for(j=hd[i];j;j=e[j].nex) {
if(e[j].r<i) {
rtr[i]=update(rtr[i],1,n,max(1,e[j].l),min(n,e[j].r),e[j].v);
}
}
}
while(m--) {
int x,y;
scanf("%d%d",&x,&y);
ll ans=0ll;
ans+=query(rtl[y],1,n,x,y);
ans-=query(rtl[x-1],1,n,x,y);
ans+=query(rtr[x],1,n,x,y);
ans-=query(rtr[y+1],1,n,x,y);
printf("%lld\n",ans);
}
return 0;
}
BZOJ 4826: [Hnoi2017]影魔 单调栈+可持久化线段树的更多相关文章
- 【bzoj4826】[Hnoi2017]影魔 单调栈+可持久化线段树
题目描述 影魔,奈文摩尔,据说有着一个诗人的灵魂.事实上,他吞噬的诗人灵魂早已成千上万.千百年来,他收集了各式各样的灵魂,包括诗人.牧师.帝王.乞丐.奴隶.罪人,当然,还有英雄.每一个灵魂,都有着自己 ...
- BZOJ 4826: [Hnoi2017]影魔 单调栈 主席树
https://www.lydsy.com/JudgeOnline/problem.php?id=4826 年少不知空间贵,相顾mle空流泪. 和上一道主席树求的东西差不多,求两种对 1. max(a ...
- 【bzoj3956】Count 单调栈+可持久化线段树
题目描述 输入 输出 样例输入 3 2 0 2 1 2 1 1 1 3 样例输出 0 3 题解 单调栈+可持久化线段树 本题是 bzoj4826 的弱化版(我为什么做题总喜欢先挑难的做QAQ) $k$ ...
- bzoj 4826: [Hnoi2017]影魔 [主席树 单调栈]
4826: [Hnoi2017]影魔 题意:一个排列,点对\((i,j)\),\(p=max(i+1,j-1)\),若\(p<a_i,a_j\)贡献p1,若\(p\)在\(a_1,a_2\)之间 ...
- BZOJ:4826: [Hnoi2017]影魔
Description 影魔,奈文摩尔,据说有着一个诗人的灵魂.事实上,他吞噬的诗人灵魂早已成千上万.千百年来,他收集了各式各样的灵魂,包括诗人.牧师.帝王.乞丐.奴隶.罪人,当然,还有英雄.每一个灵 ...
- [BZOJ 3218] A + B Problem 【可持久化线段树 + 网络流】
题目连接:BZOJ - 3218 题目分析 题目要求将 n 个点染成黑色或白色,那么我们可以转化为一个最小割模型. 我们规定一个点 i 最后属于 S 集表示染成黑色,属于 T 集表示染成白色,那么对于 ...
- Bzoj 4408: [Fjoi 2016]神秘数 可持久化线段树,神题
4408: [Fjoi 2016]神秘数 Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 177 Solved: 128[Submit][Status ...
- BZOJ 4408: [Fjoi 2016]神秘数 可持久化线段树
4408: [Fjoi 2016]神秘数 题目连接: http://www.lydsy.com/JudgeOnline/problem.php?id=4408 Description 一个可重复数字集 ...
- BZOJ 4826 [Hnoi2017]影魔 ——扫描线 单调栈
首先用单调栈和扫描线处理出每一个数左面最近的比他大的数在$l[i]$,右面最近的比他大的数$r[i]$. 然后就可以考虑每种贡献是在什么时候产生的. 1.$(l[i],r[i])$产生$p1$的贡献 ...
随机推荐
- SpringBoot第十二篇:整合jsp
作者:追梦1819 原文:https://www.cnblogs.com/yanfei1819/p/10953600.html 版权声明:本文为博主原创文章,转载请附上博文链接! 引言 Sprin ...
- 基于JRebel开发的MybatisPlus热加载插件
前言 前天项目中使用了mybatis-plus,但是搭配Jrebel开发项目时,发现修改mapper的xml,或者mapper方法中的注解,Jrebel并没有能够reload mapper.于是就有了 ...
- Gin框架 - 项目目录
概述 今天给大家分享,在 API 端使用 Gin 框架时,项目的目录. 目录 ├─ Project Name │ ├─ config //配置文件 │ ├── ... │ ├─ controller ...
- mvn手动上传jar到本地仓库
mvn install:install-file -Dfile=G:\elastic-project\workspace\out\artifacts\xxl_job_core_jar\xxl-job- ...
- Redis学习之zskiplist跳跃表源码分析
跳跃表的定义 跳跃表是一种有序数据结构,它通过在每个结点中维持多个指向其他结点的指针,从而达到快速访问其他结点的目的 跳跃表的结构 关于跳跃表的学习请参考:https://www.jianshu.co ...
- 转 Pytorch 教学资料
本文收集了大量PyTorch项目(备查) 转自:https://blog.csdn.net/fuckliuwenl/article/details/80554182 目录: 入门系列教程 入门实例 图 ...
- SkyWalking6.2.0版本UI参数、告警参数、指标含义中文解释
一.告警规则相关参数 二.SkyWalking UI相关参数CPM:每分钟请求调用的次数SLA: 服务等级协议(简称:SLA,全称:service level agreement).是在一定开销下为保 ...
- 汉字转拼音,TinyPinyin、Pinyin4j与JPinyin哪个库更快
1. 介绍 本文对TinyPinyin.Pinyin4j与JPinyin三个汉字转拼音库的用法.测试代码及转换的结果做一个简单的总结. TinyPinyin 适用于Java和Android的快速.低内 ...
- centos7.x下环境搭建(三)—nodejs安装
有3种方式可以安装nodejs yum安装 源码包安装 nvm方式安装 一.方式1:yum安装 这里我们指定安装8.x以上的版本 # curl --silent --location https:// ...
- Filebeat与Logstash配置SSL加密通信
为了保证应用日志数据的传输安全,我们可以使用SSL相互身份验证来保护Filebeat和Logstash之间的连接. 这可以确保Filebeat仅将加密数据发送到受信任的Logstash服务器,并确保L ...