先上一波题目 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. VS2017/VS2019 git Authentication failed for "XXXXXXXXXx"

    解决办法: 控制面板,凭证管理==>删掉 对应代码仓库地址的凭证.删掉,是删掉.因为我更新了还是没有用.

  2. Visual Studio Code如何编写运行C、C++

    Visual Studio Code如何编写运行C.C++ 作者:知乎用户链接:https://www.zhihu.com/question/30315894/answer/154979413来源:知 ...

  3. LeetCode Array Easy 283. Move Zeroes

    Description Given an array nums, write a function to move all 0's to the end of it while maintaining ...

  4. Linux学习笔记0-CentOS7关闭防火墙

    关闭防火墙 systemctl stop firewalld.service //停止firewall systemctl disable firewalld.service //禁止firewall ...

  5. jQuery实现网页放大镜功能

    京东等电商网站中可以对商品进行放大观察,本文要实现的就是模仿这个放大镜功能,大致效果如下图所示: 简要说明实现思路: 1.原图窗口与放大窗口插入的是同一个图片,不过原图窗口的图片要适当缩小,放大窗口图 ...

  6. Nginx是什么?为什么选择Nginx做服务器软件?有什么优势?

    代理服务器基础知识 Nginx是什么? 为什么选择Nginx 1.代理服务器基础知识 a.代理服务器 一般是指局域网内部的机器通过代理服务器发送请求到互联网上的服务器,代理服务器一般作用在客户端.应用 ...

  7. Vector、ArrayList、LinkedList、CopyOnWriteArrayList区别

    原创转载请注明出处:https://www.cnblogs.com/agilestyle/p/11443907.html CopyOnWriteArrayList CopyOnWriteArrayLi ...

  8. RBAC权限设计(一)

    序言 RBAC表结构 用户表 角色表 权限表 用户角色(关系)表 角色权限(关系)表 sql脚本 /* Navicat MySQL Data Transfer Source Server : 127. ...

  9. JRE和JVM的区别

    JRE和JVM的区别       JRE(JavaRuntimeEnvironment,Java运行环境),也就是Java平台.所有的Java程序都要在JRE下才能运行.JDK的工具也是Java程序, ...

  10. 【Flutter学习】之Widget数据共享之InheritedWidget

    一,概述 业务开发中经常会碰到这样的情况,多个Widget需要同步同一份全局数据,比如点赞数.评论数.夜间模式等等.在安卓中,一般的实现方式是观察者模式,需要开发者自行实现并维护观察者的列表.在flu ...