【BZOJ】1798: [Ahoi2009]Seq 维护序列seq
题目链接:http://www.lydsy.com/JudgeOnline/problem.php?id=1798
大概就是维护两个标记的线段树模板题。
设定优先级,先乘后加(只是相对的),$pushdown$的时候乘法标记直接乘,加法标记先乘上父亲的乘法标记再加上父亲的加法标记。
#include<iostream>
#include<cstdio>
#include<algorithm>
#include<vector>
#include<cstdlib>
#include<cmath>
#include<cstring>
using namespace std;
#define maxn 1001000
#define llg long long
#define yyj(a) freopen(a".in","r",stdin),freopen(a".out","w",stdout);
llg n,m,md; struct SEGMENT_TREE
{
llg val[maxn],addv[maxn],mul[maxn];
bool bj[maxn];
void init(){memset(val,,sizeof(val)); memset(mul,,sizeof(mul)); memset(addv,,sizeof(addv)); memset(bj,,sizeof(bj));} void build(llg o,llg l,llg r)
{
if (l==r)
{
addv[o]=,mul[o]=;
scanf("%lld",&val[o]);
return ;
}
llg mid=(l+r)>>,lc=o<<,rc=o<<|;
build(lc,l,mid);
build(rc,mid+,r);
val[o]=val[lc]+val[rc];
mul[o]=; addv[o]=;
} void pushdown(llg o,llg l,llg r)
{
llg lc=o<<,rc=o<<|;
mul[lc]*=mul[o],mul[lc]%=md;
mul[rc]*=mul[o],mul[rc]%=md;
addv[lc]*=mul[o],addv[lc]%=md;
addv[rc]*=mul[o],addv[rc]%=md;
addv[lc]+=addv[o],addv[lc]%=md;
addv[rc]+=addv[o],addv[rc]%=md;
val[o]=val[o]*mul[o]+addv[o]*(r-l+); val[o]%=md;
addv[o]=,mul[o]=;
} void add_(llg o,llg l,llg r,llg L,llg R,llg V)
{
pushdown(o,l,r);
if (L>r || R<l) return ;
if (l>=L && r<=R)
{
addv[o]+=V;
pushdown(o,l,r);
return ;
}
llg mid=(l+r)>>,lc=o<<,rc=o<<|;
add_(lc,l,mid,L,R,V);
add_(rc,mid+,r,L,R,V);
val[o]=val[lc]+val[rc]; val[o]%=md;
} void mul_(llg o,llg l,llg r,llg L,llg R,llg V)
{
pushdown(o,l,r);
if (L>r || R<l) return ;
if (l>=L && r<=R)
{
mul[o]*=V;
pushdown(o,l,r);
return ;
}
llg mid=(l+r)>>,lc=o<<,rc=o<<|;
mul_(lc,l,mid,L,R,V);
mul_(rc,mid+,r,L,R,V);
val[o]=val[lc]+val[rc]; val[o]%=md;
} llg sum(llg o,llg l,llg r,llg L,llg R)
{
pushdown(o,l,r);
if (L>r || R<l) return ;
if (l>=L && r<=R)
{
return val[o];
}
llg mid=(l+r)>>,lc=o<<,rc=o<<|,tot=;
tot+=sum(lc,l,mid,L,R);
tot+=sum(rc,mid+,r,L,R);
val[o]=val[lc]+val[rc]; val[o]%=md;
return tot%md;
} }tree; int main()
{
tree.init();
yyj("a");
cin>>n>>md;
tree.build(,,n);
llg T,type,l,r,v;
cin>>T;
while (T--)
{
scanf("%lld",&type);
if (type==)
{
scanf("%lld%lld%lld",&l,&r,&v);
tree.mul_(,,n,l,r,v);
}
if (type==)
{
scanf("%lld%lld%lld",&l,&r,&v);
tree.add_(,,n,l,r,v);
}
if (type==)
{
scanf("%lld%lld",&l,&r);
printf("%lld\n",tree.sum(,,n,l,r));
}
}
return ;
}
【BZOJ】1798: [Ahoi2009]Seq 维护序列seq的更多相关文章
- BZOJ 1798: [Ahoi2009]Seq 维护序列seq( 线段树 )
线段树.. 打个 mul , add 的标记就好了.. 这个速度好像还挺快的...( 相比我其他代码 = = ) 好像是#35.. ---------------------------------- ...
- bzoj 1798: [Ahoi2009]Seq 维护序列seq (线段树 ,多重标记下放)
1798: [Ahoi2009]Seq 维护序列seq Time Limit: 30 Sec Memory Limit: 64 MBSubmit: 7773 Solved: 2792[Submit ...
- bzoj 1798: [Ahoi2009]Seq 维护序列seq 线段树 区间乘法区间加法 区间求和
1798: [Ahoi2009]Seq 维护序列seq Time Limit: 1 Sec Memory Limit: 256 MB 题目连接 http://www.lydsy.com/JudgeO ...
- Bzoj 1798: [Ahoi2009]Seq 维护序列seq(线段树区间操作)
1798: [Ahoi2009]Seq 维护序列seq Time Limit: 30 Sec Memory Limit: 64 MB Description 老师交给小可可一个维护数列的任务,现在小可 ...
- 1798: [Ahoi2009]Seq 维护序列seq
1798: [Ahoi2009]Seq 维护序列seq Time Limit: 30 Sec Memory Limit: 64 MBSubmit: 2930 Solved: 1087[Submit ...
- BZOJ1798: [Ahoi2009]Seq 维护序列seq[线段树]
1798: [Ahoi2009]Seq 维护序列seq Time Limit: 30 Sec Memory Limit: 64 MBSubmit: 5504 Solved: 1937[Submit ...
- BZOJ1798: [Ahoi2009]Seq 维护序列seq
传送门 写这道题是为了get一个同时传送乘法下标和加法下标的小技巧,线段树模板题.不多说. 标记名字打错无限智力-- //BZOJ 1798 //by Cydiater //2016.9.13 #in ...
- 【BZOJ】1798: [Ahoi2009]Seq 维护序列seq(线段树)
http://www.lydsy.com/JudgeOnline/problem.php?id=1798 之前写了个快速乘..........................20多s...... 还好 ...
- bzoj 1798 [Ahoi2009]Seq 维护序列seq(线段树+传标)
[题目链接] http://www.lydsy.com/JudgeOnline/problem.php?id=1798 [题意] 给定一个序列,要求提供区间乘/加,以及区间求和的操作 [思路] 线段树 ...
随机推荐
- 关于functools模块的wraps装饰器用途
测试环境:Python3.6.2 + win10 + Pycharm2017.3 装饰器之functools模块的wraps的用途: 首先我们先写一个装饰器 # 探索functools模块wraps ...
- P2114 [NOI2014]起床困难综合症(二进制)
P2114 [NOI2014]起床困难综合症 我们开始设俩数,一个二进制表示全是1,另一个全是0(就是2147483647 和 0 辣) 蓝后跑一遍门 于是最后有4种情况 1->0,1-> ...
- 阿里云端口失效导致tomcat无法对外提供服务
下午,我们一个环境启动成功,但是却无法访问,经查看启动日志,如下: Mar 23, 2017 2:15:09 PM org.apache.coyote.http11.AbstractHttp11Pro ...
- sql xml 入门 (二)
DECLARE @myDoc xml --http://www.paymob.cn --话费充值api,充值api,话费充值接口,手机话费充值,车贝手机,贝萌手机,移动话费充值,联通话费充值,电信话费 ...
- oracle常用SQL——创建用户、表空间、授权(12C)
一.查询 查询用户所属 表空间 select username,default_tablespace from dba_users where username='xxx' 查询表空间情况 SELEC ...
- py4CV例子1猫狗大战和Knn算法
1.什么是猫狗大战: 数据集来源于Kaggle(一个为开发商和数据科学家提供举办机器学习竞赛.托管数据库.编写和分享代码的平台),原数据集有12500只猫和12500只狗,分为训练.测试两个部分. 2 ...
- Python3 tkinter基础 Listbox Scrollbar 创建垂直滚动条
Python : 3.7.0 OS : Ubuntu 18.04.1 LTS IDE : PyCharm 2018.2.4 Conda ...
- [Sdoi2017]序列计数 矩阵优化dp
题目 https://www.lydsy.com/JudgeOnline/problem.php?id=4818 思路 先考虑没有质数限制 dp是在同余系下的,所以\(f[i][j]\)表示前i个点, ...
- Win10 使用命令修复系统坏死点
我的电脑win10系统升级多次以后,经常会出现所有设置有时点不开的情况 解决: C:\WINDOWS\system32>sfc /SCANNOW 开始系统扫描.此过程将需要一些时间. 开始系统扫 ...
- 【做题】arc068_f-Solitaire——糊结论
把所有数字放入双端队列后,结果大概是这样一个排列: \[P_1 1 P_2\] 其中\(P_1\)是递减序列,\(P_2\)是递增序列. 我们以\(1\)所在的位置\(k\)分割最终的排列\(A\). ...