[JOI 2020 Final] 火事 题解
给一篇题解。(下面这张图是从 luogu 上粘贴的,因为不太会画图)
其中纵坐标为 \(t\),横坐标为 \(a_i\)。
发现同颜色块只有平行四边形和直角梯形(等腰直角三角形)两种情况。
可以将直角梯形削去左下角,分成两部分考虑。
等直可以直接暴力插入区间,总个数 \(O(n)\)。
平行四边形可以看作上三角+中平四/矩形+下三角,矩形不变,平四直接将赋值区间平移即可。
感觉最多有 \(O(n\log n)\) 个区间,加上树状数组应该是 \(O(n\log^2n)\),但是由于其中 \(dep\) 优化+根本跑不满,所以跑得飞快。
#include<bits/stdc++.h>
#define int long long
using namespace std;
const int N=2e5+5;
int n,dep,a[N],b[N];
int l[N],r[N],ga[N];
int m,tp,st[N],gb[N];
int mx,ans[N],c[N*2][3];
void add(int x,int y,int k){
for(;x<=n*2;x+=x&-x)
c[x][y]+=k;
}int sum(int x,int y){
int re=0;
for(;x;x-=x&-x)
re+=c[x][y];
return re;
}struct node{
int l,r,id;
};vector<node>qu[N];
struct upd{
int id,ad;
};vector<upd>w1[N],w2[N];
signed main(){
ios::sync_with_stdio(0);
cin.tie(0);cout.tie(0);
cin>>n>>m;
for(int i=1;i<=n;i++)
cin>>a[i],mx=max(mx,a[i]);
a[n+1]=mx+1;st[++tp]=n+1;
for(int i=n;i;i--){
while(a[i]>a[st[tp]]) tp--;
r[i]=st[tp];
if(a[i]==a[st[tp]]) st[tp]=i;
else st[++tp]=i;
}tp=0;
for(int i=1;i<=n;i++){
while(tp&&a[i]>=a[st[tp]]) tp--;
if(!st) st[++tp]=i;
else l[i]=st[tp],st[++tp]=i;
}for(int i=1;i<=n;i++)
gb[i]=r[i]-i,dep=max(dep,gb[i]);
for(int i=1;i<=n;i++){
if(!l[i]){
ga[i]=dep-gb[i]+1;
for(int j=ga[i]+1;j<=dep;j++)
w1[j].push_back({j-ga[i]-1+i,a[i]});
}else ga[i]=i-l[i];
}for(int i=1;i<=m;i++){
int t,l,r;cin>>t>>l>>r;
qu[t].push_back({l,r,i});
}for(int i=1;i<=n;i++)
b[i]=max(a[i],b[i-1]),add(i,2,b[i]);
for(int i=dep;i<=n;i++)
for(auto y:qu[i])
ans[y.id]=sum(y.r,2)-sum(y.l-1,2);
for(int i=1;i<=n;i++){
if(ga[i]>=gb[i])
for(int j=1;j<=gb[i];j++){
w1[j].push_back({i+j-1,a[i]});
w1[ga[i]+j].push_back({i+j-1,-a[i]});
}
else for(int j=1;j<=ga[i];j++){
w2[j].push_back({i-j+1,a[i]});
w2[gb[i]+j].push_back({i-j+1,-a[i]});
}
}for(int i=1;i<=dep;i++){
for(auto y:w1[i]) add(y.id,0,y.ad);
for(auto y:w2[i]) add(y.id+n,1,y.ad);
for(auto y:qu[i-1])
ans[y.id]=sum(y.r,0)-sum(y.l-1,0)+sum(y.r-i+1+n,1)-sum(y.l-i+n,1);
}for(int i=1;i<=m;i++) cout<<ans[i]<<"\n";
return 0;
}
[JOI 2020 Final] 火事 题解的更多相关文章
- JOI 2020 Final 题解
T1. 只不过是长的领带 大水题,把 \(a_i,b_i\) 从小到大排序. 发现最优方案只可能是大的 \(a_i\) 跟大的 \(b_i\) 匹配,小的 \(a_i\) 与小的 \(b_i\) 匹配 ...
- 【题解】LOJ2759. 「JOI 2014 Final」飞天鼠(最短路)
[题解]LOJ2759. 「JOI 2014 Final」飞天鼠(最短路) 考虑最终答案的构成,一定是由很多飞行+一些上升+一些下降构成. 由于在任何一个点上升或者下降代价是一样的,所以: 对于上升操 ...
- JOI 2018 Final 题解
题目列表:https://loj.ac/problems/search?keyword=JOI+2018+Final T1 寒冬暖炉 贪心 暴力考虑每相邻两个人之间的间隔,从小到大选取即可 #incl ...
- 「JOI 2017 Final」JOIOI 王国
「JOI 2017 Final」JOIOI 王国 题目描述 题目译自 JOI 2017 Final T3「 JOIOI 王国 / The Kingdom of JOIOI」 JOIOI 王国是一个 H ...
- 「JOI 2015 Final」分蛋糕 2
「JOI 2015 Final」分蛋糕 2 题解 这道题让我想起了新年趣事之红包这道DP题,这道题和那道题推出来之后的做法是一样的. 我们可以定义dp[i][len][1] 表示从第i块逆时针数len ...
- [LOJ3014][JOI 2019 Final]独特的城市——树的直径+长链剖分
题目链接: [JOI 2019 Final]独特的城市 对于每个点,它的答案最大就是与它距离最远的点的距离. 而如果与它距离为$x$的点有大于等于两个,那么与它距离小于等于$x$的点都不会被计入答案. ...
- LOJ#2351. 「JOI 2018 Final」毒蛇越狱
LOJ#2351. 「JOI 2018 Final」毒蛇越狱 https://loj.ac/problem/2351 分析: 首先有\(2^{|?|}\)的暴力非常好做. 观察到\(min(|1|,| ...
- JOI 2019 Final合集
JOI 2019 Final 合集 #3010. 「JOI 2019 Final」勇者比太郎 其实如果读懂题了就是水题了 题目就是让你求满足条件的\(JOI\),使得\(O\)在\(J\)同行的 ...
- 【LOJ】#3014. 「JOI 2019 Final」独特的城市(长链剖分)
LOJ#3014. 「JOI 2019 Final」独特的城市(长链剖分) 显然我们画一条直径,容易发现被统计的只可能是直径某个距离较远的端点到这个点的路径上的值 用一个栈统计可以被统计的点,然后我们 ...
- 「JOI 2014 Final」飞天鼠
「JOI 2014 Final」飞天鼠 显然向上爬是没有必要的,除非会下降到地面以下,才提高到刚好为0. 到达一个点有两种情况:到达高度为0和不为0. 对于高度不为0的情况,显然花费的时间越少高度越高 ...
随机推荐
- 要构建此项目,必须安装以下工作负载: wasm-tools
要构建此项目,必须安装以下工作负载: wasm-tools 要安装这些工作负载,请运行以下命令: dotnet workload restore AdminAPP C:\Program Files\d ...
- Python中构建全局字典的详细指南
在Python编程中,全局变量是指在整个程序运行期间都可以访问的变量.全局字典作为一种特殊的全局变量,可以存储各种类型的数据,包括字符串.数字.列表.元组等,这使得它在数据管理和跨模块通信方面非常有用 ...
- RocketMQ系列3:核心技术介绍
1 介绍 RocketMQ是一款分布式消息中间件,其核心技术涉及多个核心概念,包括主题.队列.消息.生产者.消费者.消费者分组以及订阅关系.以下是对这些核心技术的详细说明: 2 核心技术实现 2.1 ...
- 【YashanDB知识库】Oracle pipelined函数在YashanDB中的改写
本文内容来自YashanDB官网,原文内容请见 https://www.yashandb.com/newsinfo/7802940.html?templateId=1718516 [问题分类]功能使用 ...
- alibabacloud-jindodata
https://github.com/aliyun/alibabacloud-jindodata https://github.com/aliyun/alibabacloud-jindodata/bl ...
- "有邻"创始人:APP覆盖杭州千余小区 却还没认真想过赚钱的事
"远亲不如近邻",常被社区经济"掘金者"拿来做开场语. 在杭州,有不少互联网创业企业在深挖社区经济,例如社区O2O服务平台.杨仁斌也看中了"社区&qu ...
- 哪里有 class 告诉我?
说明 本文中的 JVM 参数和代码在 JDK 8 版本生效. 哪里有用户类? 用户类是由开发者和第三方定义的类,它是由应用程序类加载器加载的. Java 程序可以通过CLASSPATH 环境变量,JV ...
- Python 添加类型标注 | 散发着自由松散气息的代码
Python 添加类型标注 | 散发着自由松散气息的代码 Python 如此简洁,书写者在声明变量时甚至无需考虑类型. 但是简洁与复杂间,是存在一个平衡点的.当我们书写较为复杂的项目时,还是希望可以拥 ...
- 百度高效研发实战训练营-Step2
百度高效研发实战训练营Step2 2.1 代码的艺术 2.1.1<代码的艺术>目的解读 这门课程的目的主要有以下四点: (1) 了解公司与学校写代码的不同 (2) 消除对于程序员这个职业的 ...
- 重温Go语法笔记 | 结构体
结构体 多个任意类型聚合成的复合类型 1.字段拥有自己的类型和值 2.字段名必须唯一 3.字段可以是结构体 结构体的定义是一种内存布局的描述 只有实例化才会真正分配内存,必须实例化之后才能使用结构体的 ...