题目:给定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]等差数列的更多相关文章

  1. BZOJ1558 [JSOI2009]等差数列 【线段树】

    题目链接 BZOJ1558 题解 等差数列,当然是差分一下 差分值相同的连续位置形成等差数列,我们所选的两个等差数列之间可以有一个位置舍弃 例如: \(1 \; 2 \; 3 \; 6 \; 8 \; ...

  2. 洛谷P4243/bzoj1558 [JSOI2009]等差数列(线段树维护差分+爆炸恶心的合并)

    题面 首先感谢这篇题解,是思路来源 看到等差数列,就会想到差分,又有区间加,很容易想到线段树维护差分.再注意点细节,\(A\)操作完美解决 然后就是爆炸恶心的\(B\)操作,之前看一堆题解的解释都不怎 ...

  3. 【BZOJ1558】等差数列(线段树)

    [BZOJ1558]等差数列(线段树) 题面 BZOJ 题解 可以说这道题已经非常毒瘤了 怎么考虑询问操作? 如果直接将一段数分解为等差数列? 太麻烦了.... 考虑相邻的数做差, 这样等差数列变为了 ...

  4. bzoj 1558: [JSOI2009]等差数列

    Description Solution 把原数组变为差分数组,然后剩下的就十分显然了 区间查询用线段树维护 修改操作就是区间加法和两个单点修改 一个等差数列实际上就是 开头一个数字+数值相等的一段 ...

  5. BZOJ.1558.[JSOI2009]等差数列(线段树 差分)

    BZOJ 洛谷 首先可以把原序列\(A_i\)转化成差分序列\(B_i\)去做. 这样对于区间加一个等差数列\((l,r,a_0,d)\),就可以转化为\(B_{l-1}\)+=\(a_0\),\(B ...

  6. [JSOI2009]等差数列

    链接:http://www.lydsy.com/JudgeOnline/problem.php?id=1558 题解: 考虑这么用线段树进行维护,由于他有区间修改等差数列 很容易想到可以用差分数组来维 ...

  7. JSOI2009 等差数列 和 算术天才⑨与等差数列 和 CH4302 Interval GCD

    等差数列 为了检验学生的掌握情况,jyy布置了一道习题:给定一个长度为N(1≤N≤100,000)的数列,初始时第i个数为vi(vi是整数,−100,000≤vi≤100,000),学生们要按照jyy ...

  8. luogu P4243 [JSOI2009]等差数列 题解

    前言: 这题真ex... 强烈谴责在题解里面放毒瘤题链接的屑出题人! 吐 ️ 解析: 这题分成两步走. 首先,既然题目中的修改操作是区间加等差数列,那么就容易想到在差分数组上进行操作. 然后就是相当恶 ...

  9. 线段树 by yyb

    线段树 by yyb Type1 维护特殊信息 1.[洛谷1438]无聊的数列 维护一个数列,两种操作 1.给一段区间加上一个等差数列 2.单点询问值 维护等差数列 不难发现,等差数列可以写成\(ad ...

随机推荐

  1. Flask 文件和流

    当我们要往客户端发送大量的数据比较好的方式是使用流,通过流的方式来将响应内容发送给客户端,实现文件的上传功能,以及如何获取上传后的文件. 响应流的生成 Flask响应流的实现原理就是通过Python的 ...

  2. Environment.getExternalStorageDirectory()

    Environment.getExternalStorageDirectory()得到的是storage/emulated/0

  3. electron打包vue项目

    electron是什么 Electron是由Github开发,用HTML,CSS和JavaScript来构建跨平台桌面应用程序的一个开源库. Electron通过将Chromium和Node.js合并 ...

  4. 【ASP.NET Core】依赖注入高级玩法——如何注入多个服务实现类

    依赖注入在 ASP.NET Core 中起中很重要的作用,也是一种高大上的编程思想,它的总体原则就是:俺要啥,你就给俺送啥过来.服务类型的实例转由容器自动管理,无需我们在代码中显式处理. 因此,有了依 ...

  5. c 语言常量

    1,整数常量 整数常量可以是十进制.八进制或十六进制的常量.前缀指定基数:0x 或 0X 表示十六进制,0 表示八进制,不带前缀则默认表示十进制. 整数常量也可以带一个后缀,后缀是 U 和 L 的组合 ...

  6. Ubuntu16.04 + Zabbix 3.4.7 邮件报警设置

    部署了Zabbix,需要配置邮件报警,在网上找了一些教程,大多是是用的CentOS + Zabbix 2.x版本的,而且还要写脚本,感觉太麻烦了,所以自己结合其他文章摸索了一套配置方法. 先说一下环境 ...

  7. Python-socket网络编程-Day8

    目录Day8-Python socket 11.Socket 11.1.socket和file的区别: 11.2.WEB服务应用: 21.3.更多功能 21.4.socket方法: 41.5. 服务端 ...

  8. Spring Security入门(2-3)Spring Security 的运行原理 4 - 自定义登录方法和页面

    参考链接,多谢作者: http://blog.csdn.net/lee353086/article/details/52586916 http元素下的form-login元素是用来定义表单登录信息的. ...

  9. SpringBoot 概念和起步

    一.概念和由来 1.什么是 Spring Boot Spring Boot 的设计目的是用来简化新Spring应用的初始搭建以及开发过程.该框架使用特定方式来进行配置,从而使开发人员不再需要定义样板化 ...

  10. 转:NLP+句法结构(三)︱中文句法结构(CIPS2016、依存句法、文法)

    NLP+句法结构(三)︱中文句法结构(CIPS2016.依存句法.文法)转自:https://www.cnblogs.com/maohai/p/6453389.html 摘录自:CIPS2016 中文 ...