[loj3256]火灾
将问题差分,即求$\sum_{i=1}^{r}S_{i}(t)-\sum_{i=1}^{l-1}S_{i}(t)$,由于两者类似,不妨考虑前者
构造矩阵$A_{i,j}=S_{j}(i)-S_{j}(i-1)$,记初始的序列为$a_{i}$,则$S_{i}(t)=a_{i}+\sum_{j=1}^{t}A_{j,i}$
将之代入,即求$\sum_{i=1}^{r}(a_{i}+\sum_{j=1}^{t}A_{j,i})$,前者直接前缀和即可,下面考虑后者,即求矩阵$A$
对于每一个$i$,求出所有$S_{j}(i-1)=a_{i}$且$S_{j}(i)\ne a_{i}$的$A_{i,j}$,显然即包括了所有位置
具体的,这些位置形式如下:令$x=\max_{x\le i,a_{x}>a_{i}}x$(若不存在则跳过)和$y=\min_{y>i,a_{y}\ge a_{i}}y$(若不存在则为$n+1$),即$\forall i\le j<y,A_{j-x,j}=a_{x}-a_{i}$
这个用数据结构不易维护,但我们可以考虑其对某一次询问的贡献,即$(a_{x}-a_{i})\sum_{i\le j<y,j-x\le t,j\le r}1$,关于后者再简单处理即$(a_{x}-a_{i})\max(\min(y-1,t+x,r)-i+1,0)$
下面,对$\min(y-1,t+x,r)$的值分类讨论:
1.$y-1$为最小值,即$t\ge y-x$且$r\ge y$
2.$t+x$为最小值,即$i-x\le t\le y-x-1$且$r-t\ge x$
3.$r$为最小值,即$i\le r\le y-1$且$r-t\le x-1$
得出上述结果时,注意:
1.最小值还需要满足$\ge i$,否则显然贡献为0,不需要考虑
2.注意等号和不等号,使得在相等时最小值仍被唯一确定
对每一种情况分别处理(后相加),将其中后者的限制通过排序解决,前者在排序后用线段树维护即可
时间复杂度为$o(n\log n)$,可以通过
1 #include<bits/stdc++.h>
2 using namespace std;
3 #define N 200005
4 #define ll long long
5 #define pll pair<ll,ll>
6 #define mp make_pair
7 #define fi first
8 #define se second
9 #define L (k<<1)
10 #define R (L+1)
11 #define mid (l+r>>1)
12 struct Data{
13 int p,i,x,y;
14 int get(){
15 if (!p)return x;
16 return y-x;
17 }
18 };
19 vector<Data>v;
20 int n,m,t,l,r,st[N],ls[N],rs[N];
21 ll a[N],sum[N],ans[N];
22 pll f[N<<2];
23 bool cmp1(Data x,Data y){
24 return (x.y<y.y)||(x.y==y.y)&&(abs(x.p)<abs(y.p));
25 }
26 bool cmp2(Data x,Data y){
27 return (x.get()<y.get())||(x.get()==y.get())&&(abs(x.p)<abs(y.p));
28 }
29 pll merge(pll x,pll y){
30 return mp(x.fi+y.fi,x.se+y.se);
31 }
32 void update(int k,int l,int r,int x,int y,pll z){
33 if ((l>y)||(x>r))return;
34 if ((x<=l)&&(r<=y)){
35 f[k]=merge(f[k],z);
36 return;
37 }
38 update(L,l,mid,x,y,z);
39 update(R,mid+1,r,x,y,z);
40 }
41 ll query(int k,int l,int r,int x){
42 ll ans=f[k].fi+x*f[k].se;
43 if (l==r)return ans;
44 if (x<=mid)return ans+query(L,l,mid,x);
45 return ans+query(R,mid+1,r,x);
46 }
47 int main(){
48 scanf("%d%d",&n,&m);
49 for(int i=1;i<=n;i++)scanf("%lld",&a[i]);
50 for(int i=1;i<=n;i++){
51 while ((st[0])&&(a[i]>=a[st[st[0]]]))st[0]--;
52 if (st[0])ls[i]=st[st[0]];
53 st[++st[0]]=i;
54 }
55 st[0]=0;
56 for(int i=n;i;i--){
57 while ((st[0])&&(a[i]>a[st[st[0]]]))st[0]--;
58 if (st[0])rs[i]=st[st[0]];
59 st[++st[0]]=i;
60 }
61 for(int i=1;i<=n;i++){
62 if (ls[i]){
63 if (!rs[i])rs[i]=n+1;
64 v.push_back(Data{0,i,ls[i],rs[i]});
65 }
66 }
67 for(int i=1;i<=n;i++)sum[i]=sum[i-1]+a[i];
68 for(int i=1;i<=m;i++){
69 scanf("%d%d%d",&t,&l,&r);
70 ans[i]=sum[r]-sum[l-1];
71 v.push_back(Data{1,i,t,r});
72 if (l>1)v.push_back(Data{-1,i,t,l-1});
73 }
74 sort(v.begin(),v.end(),cmp1);
75 for(int i=0;i<v.size();i++){
76 if (v[i].p)ans[v[i].i]+=v[i].p*query(1,1,n,v[i].x);
77 else update(1,1,n,v[i].y-v[i].x,n,mp((a[v[i].x]-a[v[i].i])*(v[i].y-v[i].i),0));
78 }
79 sort(v.begin(),v.end(),cmp2);
80 memset(f,0,sizeof(f));
81 for(int i=0;i<v.size();i++){
82 if (v[i].p)ans[v[i].i]+=v[i].p*query(1,1,n,v[i].x);
83 else update(1,1,n,v[i].i-v[i].x,v[i].y-v[i].x-1,mp((a[v[i].x]-a[v[i].i])*(v[i].x-v[i].i+1),a[v[i].x]-a[v[i].i]));
84 }
85 memset(f,0,sizeof(f));
86 for(int i=(int)v.size()-1;i>=0;i--){
87 if (v[i].p)ans[v[i].i]+=v[i].p*query(1,1,n,v[i].y);
88 else update(1,1,n,v[i].i,v[i].y-1,mp((a[v[i].x]-a[v[i].i])*(1-v[i].i),a[v[i].x]-a[v[i].i]));
89 }
90 for(int i=1;i<=m;i++)printf("%lld\n",ans[i]);
91 }
[loj3256]火灾的更多相关文章
- 【OpenCV】基于图像处理和模式识别的火灾检测方法
学期末一直忙考试,大作业,很久没来CSDN耕耘了... 虽然考试都结束了,手头还是累积了不少活儿要补,不多写了,晒个小项目,之前一直做的,后来当做模式识别课程的大作业交了. 大体框架如下: 还是之前的 ...
- Arduino+sim800C家居安防火灾报警 拨打电话 发送短信例程程序
家居安防报警器,参考程序. 火灾报警 涉及用sim800c发短信,拨打电话通知. 接线: Sim800c 3.3V -> Arduino 3.3V Sim800c GND -> Ardui ...
- 2022极端高温!机器学习如何预测森林火灾?⛵ 万物AI
作者:ShowMeAI编辑部 声明:版权所有,转载请联系平台与作者并注明出处 收藏ShowMeAI查看更多精彩内容 今年夏天,重庆北碚区山火一路向国家级自然保护区缙云山方向蔓延.为守护家园,数万名重庆 ...
- 程序员装B指南
一.准备工作 "工欲善其事必先利其器." 1.电脑不一定要配置高,但是双屏是必须的,越大越好,能一个横屏一个竖屏更好.一个用来查资料,一个用来写代码.总之要显得信息量很大,效率很高 ...
- 使用Hystrix提高系统可用性
今天稍微复杂点的互联网应用,服务端基本都是分布式的,大量的服务支撑起整个系统,服务之间也难免有大量的依赖关系,依赖都是通过网络连接起来. (图片来源:https://github.com/Netfli ...
- 构建高可用ZooKeeper集群
ZooKeeper 是 Apache 的一个顶级项目,为分布式应用提供高效.高可用的分布式协调服务,提供了诸如数据发布/订阅.负载均衡.命名服务.分布式协调/通知和分布式锁等分布式基础服务.由于 Zo ...
- 【Pyrosim案例】02:简单燃烧
1 案例说明 本案例介绍一个简单的燃烧模拟. 本案例通过指定热释放率(Heat Release Rate,HRR)来定义一个500kW的燃烧火焰.利用热释放率来定义燃烧火焰在火灾安全工程中描述火焰的一 ...
- MSP430FR2系列单片机破解芯片解密多少钱?
MSP430FR2系列单片机破解芯片解密 MSP430FR2xx系列单片机芯片解密型号: MSP430FR2533.MSP430FR2110.MSP430FR2310.MSP430FR2311.MSP ...
- jQuery Colorbox弹窗插件使用教程小结、属性设置详解
jQuery Colorbox是一款弹出层,内容播放插件,效果极佳,当然我主要是用来弹出图片啦. jQuery Colorbox不仅有弹性动画效果,淡入淡出效果,幻灯片播放,宽度自定义,还能够ajax ...
随机推荐
- 🚴♂️全套MySQL数据库教程_Mysql基础入门教程,零基础小白自学MySQL数据库必备教程☔ #002 # 第二单元 MySQL数据类型、操作表#
二.本单元知识点概述 (Ⅰ)知识点概述 二.本单元教学目标 (Ⅰ)重点知识目标 1.Mysql的数据类型2.如何选择数据类型3.创建表4.修改表5.删除表 (Ⅱ)能力目标 1.熟练创建数据库及删除数据 ...
- 使用node-gyp编写简单的node原生模块
通过样例,让我们了解如何编写一个node的原生模块.当然,这篇文章还有一个目的,是为了方便以后编写关于node-gyp的文章,搭建初始环境. 基于node-addon-api 基于node-addon ...
- [kuangbin带你飞]专题一 简单搜索 棋盘问题
题来:链接https://vjudge.net/problem/OpenJ_Bailian-132 J - 棋盘问题 1.题目: 在一个给定形状的棋盘(形状可能是不规则的)上面摆放棋子,棋子没有区别. ...
- NX CAM 区域轮廓铣的切削步长
从NX3.0到NX9.0,默认都是5%.可是实际计算的精确度是不一样的.到NX8.0上发现计算速度特别慢,后来东找西找,设置这个参数可以解决.PS:请慎用!请后后面的官方解释. 官方的解释是: &qu ...
- 「软件测试实战教程系列(三)」弃繁就简,接口测试神器Postman|收藏版
软件测试实战教程系列(三)弃繁就简,接口测试神器Postman|收藏版 Postman主要帮我们干了三件事: 1.把相关集合放到一个集合当中方便管理. 2.对指定接口发送请求. 3.断言 下面我们使用 ...
- UML图 | 时序图(顺序、序列图)绘制
上一次写过一篇 UML | 类图 相关的文章,平时规范开发会用的上,或者是写什么文档,就还是需要画图,就像毕业设计就是如此.希望能够帮助到大家. 注:本文中所用画图软件为 Microsoft Visi ...
- PromQL的简单使用
PromQL的简单使用 一.背景 二.PromQL的数据类型 三.字面量 1.字符串字面量 2.浮点数字面量 四.时间序列选择器 1.即时向量选择器 1.组成部分 2.指标名称和匹配器的组合 3.匹配 ...
- arduino 使用 analogRead 读取不到数据,digitalRead 却可以正常读取
项目场景: 最近在使用安信可的 ESP32S P14 引脚(ADC 16)读取一个电路状态的时候遇到一个问题,电路状态不是很稳定,在高电平的时候,会突然出现毫秒级的波动,出现短暂的低电平,造成设备状态 ...
- hdu 5178 pairs(BC第一题,,方法不止一种,,我用lower_bound那种。。。)
题意: X坐标上有n个数.JOHN想知道有多少对数满足:x[a]-x[b]<=k(题意给)[a<b] 思路: 额,,,直接看代码吧,,,, 代码: int T,n,k; int x[100 ...
- 第07课 OpenGL 光照和键盘(1)
光照和键盘控制: 在这一课里,我们将添加光照和键盘控制,它让程序看起来更美观. 这一课我会教您如何使用三种不同的纹理滤波方式.教您如何使用键盘来移动场景中的对象,还会教您在OpenGL场景中应用简单的 ...