洛谷 P2023 维护序列——线段树
先上一波题目 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 维护序列——线段树的更多相关文章
- 洛谷 P2023 维护序列 题解
题面 注意一个细节,查询和更新都需要pushdown(); #include <bits/stdc++.h> #define int long long using namespace s ...
- [P2023][AHOI2009]维护序列(线段树)
题目描述 老师交给小可可一个维护数列的任务,现在小可可希望你来帮他完成. 有长为N的数列,不妨设为a1,a2,…,aN .有如下三种操作形式: (1)把数列中的一段数全部乘一个值; (2)把数列中的一 ...
- 【BZOJ】1012: [JSOI2008]最大数maxnumber /【洛谷】1198(线段树)
Description 现在请求你维护一个数列,要求提供以下两种操作:1. 查询操作.语法:Q L 功能:查询当前数列中末尾L个数中的最大的数,并输出这个数的值.限制:L不超过当前数列的长度.2. 插 ...
- 洛谷题解P4314CPU监控--线段树
题目链接 https://www.luogu.org/problemnew/show/P4314 https://www.lydsy.com/JudgeOnline/problem.php?id=30 ...
- BZOJ 1500 洛谷2042维护序列题解
BZ链接 洛谷链接 这道题真是丧心病狂.... 应该很容易就可以看出做法,但是写代码写的....... 思路很简单,用一个平衡树维护一下所有的操作就好了,重点讲解一下代码的细节 首先如果按照常规写法的 ...
- BZOJ 1798 AHOI2009 Seq 维护序列 线段树
题目大意:维护一个序列,提供三种操作: 1.将区间中每个点的权值乘上一个数 2.将区间中每个点的权值加上一个数 3.求一段区间的和对p取模的值 2631的超^n级弱化版.写2631之前能够拿这个练练手 ...
- 【洛谷P2894】Hotel 线段树+二分查询
题目大意:给定一个长度为 N 的序列,每个点有两种状态 1/0,表示占有和空闲,现支持 first-fit 查询是否有一段连续的长度为 X 的空闲子序列和区间赋值操作. 题解:get到了线段树新技能. ...
- 洛谷P3372/poj3468(线段树lazy_tag)(询问区间和,支持区间修改)
洛谷P3372 //线段树 询问区间和,支持区间修改 #include <cstdio> using namespace std; struct treetype { int l,r; l ...
- 洛谷P4065 [JXOI2017]颜色(线段树)
题意 题目链接 Sol 线段树板子题都做不出来,真是越来越菜了.. 根据题目描述,一个合法区间等价于在区间内的颜色没有在区间外出现过. 所以我们可以对于每个右端点,统计最长的左端点在哪里,刚开始以为这 ...
随机推荐
- Vim使用taglist功能
下载 wget http://www.vim.org/scripts/download_script.php?src_id=19574 -O taglist.zip 然后解压taglist.zip到~ ...
- loadrunner 快捷键
lr 不同的界面切换 crt f6lr:选中要查找的内容 ctrl +f3 超找文本 选中所有字母大写 ctl +shift+ u;小写
- PTA 紧急救援 /// dijkstra 最短路数 输出路径
题目大意: 给定 n m s t :表示n个点编号为0~n-1 m条边 起点s终点t 接下来一行给定n个数:表示第i个点的救援队数量 接下来m行给定u v w:表示点u到点v有一条长度为w的边 求从s ...
- RabbitMq--2--安装
简单说下个人的理解,mq就是一个消息代理,负责异步消息转发,可以很大程度缓解服务器压力,并且防止服务器宕机影响业务等. 安装: 环境:centos7 1).首先需要安装erlang #wget htt ...
- Python 的PIL,可以解决ImportError The _imagingft C module is not installed
删除PIL相关文件 mv PIL /tmp pip install Pillow 安装Pillow后, 可能还会发生KeyError的错误, 检查项目源码后发现是 Image 模块的save函数中 ...
- Vue-router路由的简单使用
一.安装路由: 如果使用vue-cli脚手架搭建,项目创建过程中会提示你自否选择使用vue-router,选择使用即可, 二.创建组件 1.vue-cli项目自动创建的路由文件是src包下面的rout ...
- 【转】IntelliJ IDEA 2016.1.3注册破解激活
http://blog.csdn.net/c1481118216/article/details/51773674
- Ubuntu下安装chrome浏览器步骤
进入 Ubuntu 18.04 桌面,按下 Ctrl + Alt + t 键盘组合键,启动终端. 也可以按下 Win 键(或叫 Super 键),在 Dash 的搜索框中输入 terminal 或“终 ...
- OkHttp的使用
Download OkHttp3 implementation 'com.squareup.okhttp3:okhttp:3.10.0' 1.1. 异步GET请求 -new OkHttpClient; ...
- 【记录】Mybatis Generator生成数据对象Date/TimeStamp 查询时间格式化
Mybatis Generator是很好的工具帮助我们生成表映射关联代码,最近博主遇到一个问题,找了很久才解决, 就是用Mybatis Generator生成实体类的时候,Date 时间无法格式化输出 ...