先上一波题目 https://www.luogu.org/problem/P2023

复习了一波线段树 题目涉及的操作有区间加 区间乘以及区间求和

tips:线段树在传标记的时候 优先传乘法标记再传加法标记 规定好顺序就不会错了

#include<cstdio>
#include<cstring>
#include<algorithm>
#define LL long long
using namespace std;
const int M=;
LL read(){
LL ans=,f=,c=getchar();
while(c<''||c>''){if(c=='-') f=-; c=getchar();}
while(c>=''&&c<=''){ans=ans*+(c-''); c=getchar();}
return ans*f;
}
int n,L,R;
LL C,mod;
struct node{
int l,r;
LL ad,mx,sum;
}e[M*];
void up(int x){e[x].sum=(e[x<<].sum+e[x<<^].sum)%mod;}
void build(int x,int l,int r){
e[x].l=l; e[x].r=r;
e[x].ad=; e[x].mx=;
if(l==r){e[x].sum=read()%mod; return ;}
int mid=(l+r)>>;
build(x<<,l,mid);
build(x<<^,mid+,r);
up(x);
}
void down(int x){
LL ad=e[x].ad,mx=e[x].mx;
LL ls=x<<,rs=x<<^,len1=e[ls].r-e[ls].l+,len2=e[rs].r-e[rs].l+;
if(mx!=){
e[ls].sum=e[ls].sum*mx%mod;
e[ls].ad=e[ls].ad*mx%mod;
e[ls].mx=e[ls].mx*mx%mod;
e[rs].sum=e[rs].sum*mx%mod;
e[rs].ad=e[rs].ad*mx%mod;
e[rs].mx=e[rs].mx*mx%mod;
e[x].mx=;
}
if(ad){
e[ls].sum=(e[ls].sum+ad*len1%mod)%mod;
e[ls].ad=(e[ls].ad+ad)%mod;
e[rs].sum=(e[rs].sum+ad*len2%mod)%mod;
e[rs].ad=(e[rs].ad+ad)%mod;
e[x].ad=;
}
}
void dmx(int x){
if(L<=e[x].l&&e[x].r<=R){
e[x].sum=e[x].sum*C%mod;
e[x].ad=e[x].ad*C%mod;
e[x].mx=e[x].mx*C%mod;
return ;
}
down(x);
int mid=(e[x].l+e[x].r)>>;
if(L<=mid) dmx(x<<);
if(R>mid) dmx(x<<^);
up(x);
}
void dadd(int x){
if(L<=e[x].l&&e[x].r<=R){
LL len=e[x].r-e[x].l+;
e[x].sum=(e[x].sum+C*len%mod)%mod;
e[x].ad=(e[x].ad+C)%mod;
return ;
}
down(x);
int mid=(e[x].l+e[x].r)>>;
if(L<=mid) dadd(x<<);
if(R>mid) dadd(x<<^);
up(x);
}
LL push(int x){
if(L<=e[x].l&&e[x].r<=R) return e[x].sum;
down(x);
int mid=(e[x].l+e[x].r)>>;
LL ans=;
if(L<=mid) ans=(ans+push(x<<))%mod;
if(R>mid) ans=(ans+push(x<<^))%mod;
up(x);
return ans;
}
int k,m;
int main(){
n=read(); mod=read();
build(,,n);
m=read();
for(int i=;i<=m;i++){
k=read(); L=read(); R=read();
if(k==) C=read()%mod,dmx();
else if(k==) C=read()%mod,dadd();
else printf("%lld\n",push());
}
return ;
}

洛谷 P2023 维护序列——线段树的更多相关文章

  1. 洛谷 P2023 维护序列 题解

    题面 注意一个细节,查询和更新都需要pushdown(); #include <bits/stdc++.h> #define int long long using namespace s ...

  2. [P2023][AHOI2009]维护序列(线段树)

    题目描述 老师交给小可可一个维护数列的任务,现在小可可希望你来帮他完成. 有长为N的数列,不妨设为a1,a2,…,aN .有如下三种操作形式: (1)把数列中的一段数全部乘一个值; (2)把数列中的一 ...

  3. 【BZOJ】1012: [JSOI2008]最大数maxnumber /【洛谷】1198(线段树)

    Description 现在请求你维护一个数列,要求提供以下两种操作:1. 查询操作.语法:Q L 功能:查询当前数列中末尾L个数中的最大的数,并输出这个数的值.限制:L不超过当前数列的长度.2. 插 ...

  4. 洛谷题解P4314CPU监控--线段树

    题目链接 https://www.luogu.org/problemnew/show/P4314 https://www.lydsy.com/JudgeOnline/problem.php?id=30 ...

  5. BZOJ 1500 洛谷2042维护序列题解

    BZ链接 洛谷链接 这道题真是丧心病狂.... 应该很容易就可以看出做法,但是写代码写的....... 思路很简单,用一个平衡树维护一下所有的操作就好了,重点讲解一下代码的细节 首先如果按照常规写法的 ...

  6. BZOJ 1798 AHOI2009 Seq 维护序列 线段树

    题目大意:维护一个序列,提供三种操作: 1.将区间中每个点的权值乘上一个数 2.将区间中每个点的权值加上一个数 3.求一段区间的和对p取模的值 2631的超^n级弱化版.写2631之前能够拿这个练练手 ...

  7. 【洛谷P2894】Hotel 线段树+二分查询

    题目大意:给定一个长度为 N 的序列,每个点有两种状态 1/0,表示占有和空闲,现支持 first-fit 查询是否有一段连续的长度为 X 的空闲子序列和区间赋值操作. 题解:get到了线段树新技能. ...

  8. 洛谷P3372/poj3468(线段树lazy_tag)(询问区间和,支持区间修改)

    洛谷P3372 //线段树 询问区间和,支持区间修改 #include <cstdio> using namespace std; struct treetype { int l,r; l ...

  9. 洛谷P4065 [JXOI2017]颜色(线段树)

    题意 题目链接 Sol 线段树板子题都做不出来,真是越来越菜了.. 根据题目描述,一个合法区间等价于在区间内的颜色没有在区间外出现过. 所以我们可以对于每个右端点,统计最长的左端点在哪里,刚开始以为这 ...

随机推荐

  1. QTP调用.net Framework类库实例

    1. 日期时间格式处理 set oDate = DotNetFactory.CreateInstance("System.DateTime").Parse("2-18-2 ...

  2. Cocos2d-x之Menu

    |   版权声明:本文为博主原创文章,未经博主允许不得转载. cocos2d-x菜单简介: 菜单也是游戏开发中的重要环节,一般游戏开始的第一个画面都是游戏主菜单,这些菜单包括,开始游戏,游戏设置,关卡 ...

  3. <每日一题>题目4:for循环套生成器的面试题

    题目: def add(n,i): return n+i def test(): for i in range(4): yield i g = test() for n in [1,10,5]: g ...

  4. go 学习之函数

    个人把go函数理解分三种: 1.普通函数 普通函数声明: func name(parameter-list) (result-list) { body} package main import &qu ...

  5. 不要62(数位dp)

    题目传送门 不要62 Time Limit: 1000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total ...

  6. SSL连接出现的问题

    客户端向服务器发送数据时,份两种情况,SSL单向验证和SSL双向验证 1.SSL单向验证时 代码如下: import java.io.IOException; import java.util.Has ...

  7. 修改默认runlevel

    CentOS直接修改文件  /etc/inittab 就好了 # Default runlevel. The runlevels used are: # - halt (Do NOT set init ...

  8. MongoDB--副本集基本信息

    副本集的概念 副本集是一组服务器,其中有一个是主服务器(primary),用于处理客户端请求:还有多个备份服务器(secondary),用于保存主服务器的数据副本.如果主服务器崩溃了,备份服务器会自动 ...

  9. Python3.5-20190513-廖老师-自我笔记-函数式编程

    把复杂的任务拆成各个小的函数,通过函数的调用来完成任务.这就是面向过程编程. 高阶函数:就是让函数的参数能够接收别的函数.把函数作为参数传入到另一个函数. 函数名也是变量.和变量用法一样的,指向一个函 ...

  10. Spring boot与thymeleaf的集成

    # thymeleaf热部署 spring.thymeleaf.cache=false @Value("${spring.thymeleaf.cache}")          p ...