先上一波题目 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. Python字节码与解释器学习

    参考:http://blog.jobbole.com/55327/ http://blog.jobbole.com/56300/ http://blog.jobbole.com/56761/ 1. 在 ...

  2. 平衡二叉搜索树AVL

    package com.sunshine.AlgorithmTemplate; import com.sunshine.OFFER66_SECOND.BalanceTreeNode; import c ...

  3. docker 提示 Drive has not been shared 错误

    Creating laradock_docker-in-docker_1 ... Creating laradock_docker-in-docker_1 ... error ERROR: for l ...

  4. vue如何配置路由 、获取路由的参数、部分刷新页面、缓存页面

    vue如何配置路由 .获取路由的参数.部分刷新页面.缓存页面:http://www.mamicode.com/info-detail-1941546.html vue-router传递参数的几种方式: ...

  5. 插件化框架解读之android系统服务实现原理(五)

    阿里P7移动互联网架构师进阶视频(每日更新中)免费学习请点击:https://space.bilibili.com/474380680 一.系统服务提供方式 1.我们平时最常见的系统服务使用方式 Wi ...

  6. 初识Flink广播变量broadcast

    Broadcast 广播变量:可以理解为是一个公共的共享变量,我们可以把一个dataset 或者不变的缓存对象(例如map list集合对象等)数据集广播出去,然后不同的任务在节点上都能够获取到,并在 ...

  7. C# DataTable转json 时间格式化

    1.NewTonSoft.json public static string DataTableToJson(DataTable dt) { ) { return ""; } el ...

  8. 试试监听输入框的值 (eq:在未输入前,按钮为灰色,输入内容后,按钮变蓝色)

    参考网址:https://blog.csdn.net/tel13259437538/article/details/78927071

  9. C++中static的作用

    tatic关键字有俩作用:(1).控制存储分配:(2).控制一个名字的可见性和连接.   随着C++名字空间的引入,我们有了更好的,更灵活的方法来控制一个大项目的名字增长.     在类的内部使用st ...

  10. Sublime Text 3 - there are no packages available for installation 解决方法

    解决方法: 1. 下载一个channel_v3.json ,  提取码: n2vc 2. 进入以下路径的设置界面 3. 添加代码 , 文件路径以各自下载保存路径为准 ( 重启sublime, 搞定 ! ...