[bzoj1558][JSOI2009]等差数列
题目:给定n个数,m个操作,每次给一段区间加一个等差数列或者询问一段区间至少要用多少个等差数列来表示。$n,m\leqslant 10^{5}$
题解:老套路,维护差分数组,修改操作变成了两个单点加和一个区间加。然后我们用线段树维护,合并答案的时候复杂一点,s[0/1][0/1]表示左右端点取不取的答案就行啦。
#include<iostream>
#include<cstdio>
#define MN 100000
using namespace std;
inline int read()
{
int x = , f = ; char ch = getchar();
while(ch < '' || ch > ''){ if(ch == '-') f = -; ch = getchar();}
while(ch >= '' && ch <= ''){x = x * + ch - '';ch = getchar();}
return x * f;
} int n,q,s[MN+];
char op[]; inline void re(int&x,int y){if(y<x) x=y;} struct data
{
int s[],l,r;
data operator + (data y)
{
data c;c.l=l;c.r=y.r;
c.s[]=s[]+y.s[]-(r==y.l);
re(c.s[],s[]+y.s[]);re(c.s[],s[]+y.s[]);
c.s[]=s[]+y.s[]-(r==y.l);
re(c.s[],s[]+y.s[]);re(c.s[],s[]+y.s[]);
c.s[]=s[]+y.s[]-(r==y.l);
re(c.s[],s[]+y.s[]);re(c.s[],s[]+y.s[]);
c.s[]=s[]+y.s[]-(r==y.l);
re(c.s[],s[]+y.s[]);re(c.s[],s[]+y.s[]);
return c;
}
};
struct node{
int l,r,val;data x;
}T[MN*+]; void pushdown(int x)
{
int l=x<<,r=x<<|;
T[l].val+=T[x].val;T[r].val+=T[x].val;
T[l].x.l+=T[x].val;T[l].x.r+=T[x].val;
T[r].x.l+=T[x].val;T[r].x.r+=T[x].val;
T[x].val=;
} void build(int x,int l,int r)
{
if((T[x].l=l)==(T[x].r=r))
{
T[x].x.s[]=;T[x].x.l=T[x].x.r=s[l];
T[x].x.s[]=T[x].x.s[]=T[x].x.s[]=;
return;
}
int mid=l+r>>;
build(x<<,l,mid);build(x<<|,mid+,r);
T[x].x=T[x<<].x+T[x<<|].x;
} data query(int x,int l,int r)
{
//cout<<"query"<<x<<" "<<l<<" "<<r<<" "<<T[x].l<<" "<<T[x].r<<endl;
if(T[x].l==l&&T[x].r==r) return T[x].x;
if(T[x].val) pushdown(x);
int mid=T[x].l+T[x].r>>;
if(r<=mid) return query(x<<,l,r);
else if(l>mid) return query(x<<|,l,r);
else return query(x<<,l,mid)+query(x<<|,mid+,r);
} void modify(int x,int l,int r,int ad)
{
if(T[x].l==l&&T[x].r==r)
{
T[x].val+=ad;T[x].x.l+=ad;T[x].x.r+=ad;
return;
}
if(T[x].val) pushdown(x);
int mid=T[x].l+T[x].r>>;
if(r<=mid) modify(x<<,l,r,ad);
else if(l>mid) modify(x<<|,l,r,ad);
else modify(x<<,l,mid,ad),modify(x<<|,mid+,r,ad);
T[x].x=T[x<<].x+T[x<<|].x;
} int main()
{
n=read();
for(int i=;i<=n;i++) s[i]=read();
for(int i=;i<n;i++) s[i]=s[i+]-s[i];
build(,,n-);
for(q=read();q;q--)
{
scanf("%s",op);int l=read(),r=read();
if(op[]=='B') l==r?puts(""):printf("%d\n",query(,l,r-).s[]);
else
{
int a=read(),b=read();
if(l!=) modify(,l-,l-,a);
if(l!=r) modify(,l,r-,b);
if(r!=n) modify(,r,r,-(a+(r-l)*b));
}
}
return ;
}
[bzoj1558][JSOI2009]等差数列的更多相关文章
- BZOJ1558 [JSOI2009]等差数列 【线段树】
题目链接 BZOJ1558 题解 等差数列,当然是差分一下 差分值相同的连续位置形成等差数列,我们所选的两个等差数列之间可以有一个位置舍弃 例如: \(1 \; 2 \; 3 \; 6 \; 8 \; ...
- 洛谷P4243/bzoj1558 [JSOI2009]等差数列(线段树维护差分+爆炸恶心的合并)
题面 首先感谢这篇题解,是思路来源 看到等差数列,就会想到差分,又有区间加,很容易想到线段树维护差分.再注意点细节,\(A\)操作完美解决 然后就是爆炸恶心的\(B\)操作,之前看一堆题解的解释都不怎 ...
- 【BZOJ1558】等差数列(线段树)
[BZOJ1558]等差数列(线段树) 题面 BZOJ 题解 可以说这道题已经非常毒瘤了 怎么考虑询问操作? 如果直接将一段数分解为等差数列? 太麻烦了.... 考虑相邻的数做差, 这样等差数列变为了 ...
- bzoj 1558: [JSOI2009]等差数列
Description Solution 把原数组变为差分数组,然后剩下的就十分显然了 区间查询用线段树维护 修改操作就是区间加法和两个单点修改 一个等差数列实际上就是 开头一个数字+数值相等的一段 ...
- BZOJ.1558.[JSOI2009]等差数列(线段树 差分)
BZOJ 洛谷 首先可以把原序列\(A_i\)转化成差分序列\(B_i\)去做. 这样对于区间加一个等差数列\((l,r,a_0,d)\),就可以转化为\(B_{l-1}\)+=\(a_0\),\(B ...
- [JSOI2009]等差数列
链接:http://www.lydsy.com/JudgeOnline/problem.php?id=1558 题解: 考虑这么用线段树进行维护,由于他有区间修改等差数列 很容易想到可以用差分数组来维 ...
- JSOI2009 等差数列 和 算术天才⑨与等差数列 和 CH4302 Interval GCD
等差数列 为了检验学生的掌握情况,jyy布置了一道习题:给定一个长度为N(1≤N≤100,000)的数列,初始时第i个数为vi(vi是整数,−100,000≤vi≤100,000),学生们要按照jyy ...
- luogu P4243 [JSOI2009]等差数列 题解
前言: 这题真ex... 强烈谴责在题解里面放毒瘤题链接的屑出题人! 吐 ️ 解析: 这题分成两步走. 首先,既然题目中的修改操作是区间加等差数列,那么就容易想到在差分数组上进行操作. 然后就是相当恶 ...
- 线段树 by yyb
线段树 by yyb Type1 维护特殊信息 1.[洛谷1438]无聊的数列 维护一个数列,两种操作 1.给一段区间加上一个等差数列 2.单点询问值 维护等差数列 不难发现,等差数列可以写成\(ad ...
随机推荐
- JAVAGUI设计步骤
①创建容器 首先要创建一个GUI应用程序,需要创建一个用于容纳所有其它GUI组件元素的载体,Java中称为容器.典型的包括窗口(Window).框架(Frame/JFrame).对话框(Dialog/ ...
- 限定 edittext 的 输入内容
<EditText android:id="@+id/idNumber" style="@style ...
- oc中protocol、category和继承的区别
OC中protocol.category和继承的区别以前还是有点迷糊,面试的时候说的有点混乱,现在结合一些资料总结一下. 利用继承,多态是一个很好的保持"对扩展开放.对更改封闭"( ...
- 【iOS】swift 让程序挂起后,能在后台继续运行任务
1,程序的挂起和退出 由于iOS设备资源有限.当用户点击了home键,或者另一个应用程序启动了.那么原先那个程序便进入后台被挂起,不是退出,只是停止执行代码,同时它的内存被锁定.当应用程序恢复时,它会 ...
- Node入门教程(2)第一章:NodeJS 概述
Node 概述 什么是 Node Node.js® is a JavaScript runtime built on Chrome's V8 JavaScript engine. Node.js us ...
- [Redis源码阅读]redis持久化
作为web开发的一员,相信大家的面试经历里少不了会遇到这个问题:redis是怎么做持久化的? 不急着给出答案,先停下来思考一下,然后再看看下面的介绍.希望看了这边文章后,你能够回答这个问题. 为什么需 ...
- Web Api 过滤器之 ExceptionFilter 异常过滤器
一.服务器出现异常,会统一向客户端返回 500 的错误. [RoutePrefix("api/test")] public class TestController : ApiCo ...
- python之celery的使用(一)
前段时间需要使用rabbitmq做写缓存,一直使用pika+rabbitmq的组合,pika这个模块虽然可以很直观地操作rabbitmq,但是官方给的例子太简单,对其底层原理了解又不是很深,遇到很多坑 ...
- confluence搭建详情
Confluence安装&破解&汉化 编辑时间: 2017年7月7日18:01:13 1.介绍 Atlassian Confluence(简称Confluence)是一个专业的wiki ...
- express实践(一)
涉及以下这些内容: 主体. cookie.session 数据 模板引擎 服务器基本结构: const express=require('express'); const static=require ...