题目链接: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的更多相关文章

  1. BZOJ 1798: [Ahoi2009]Seq 维护序列seq( 线段树 )

    线段树.. 打个 mul , add 的标记就好了.. 这个速度好像还挺快的...( 相比我其他代码 = = ) 好像是#35.. ---------------------------------- ...

  2. bzoj 1798: [Ahoi2009]Seq 维护序列seq (线段树 ,多重标记下放)

    1798: [Ahoi2009]Seq 维护序列seq Time Limit: 30 Sec  Memory Limit: 64 MBSubmit: 7773  Solved: 2792[Submit ...

  3. bzoj 1798: [Ahoi2009]Seq 维护序列seq 线段树 区间乘法区间加法 区间求和

    1798: [Ahoi2009]Seq 维护序列seq Time Limit: 1 Sec  Memory Limit: 256 MB 题目连接 http://www.lydsy.com/JudgeO ...

  4. Bzoj 1798: [Ahoi2009]Seq 维护序列seq(线段树区间操作)

    1798: [Ahoi2009]Seq 维护序列seq Time Limit: 30 Sec Memory Limit: 64 MB Description 老师交给小可可一个维护数列的任务,现在小可 ...

  5. 1798: [Ahoi2009]Seq 维护序列seq

    1798: [Ahoi2009]Seq 维护序列seq Time Limit: 30 Sec  Memory Limit: 64 MBSubmit: 2930  Solved: 1087[Submit ...

  6. BZOJ1798: [Ahoi2009]Seq 维护序列seq[线段树]

    1798: [Ahoi2009]Seq 维护序列seq Time Limit: 30 Sec  Memory Limit: 64 MBSubmit: 5504  Solved: 1937[Submit ...

  7. BZOJ1798: [Ahoi2009]Seq 维护序列seq

    传送门 写这道题是为了get一个同时传送乘法下标和加法下标的小技巧,线段树模板题.不多说. 标记名字打错无限智力-- //BZOJ 1798 //by Cydiater //2016.9.13 #in ...

  8. 【BZOJ】1798: [Ahoi2009]Seq 维护序列seq(线段树)

    http://www.lydsy.com/JudgeOnline/problem.php?id=1798 之前写了个快速乘..........................20多s...... 还好 ...

  9. bzoj 1798 [Ahoi2009]Seq 维护序列seq(线段树+传标)

    [题目链接] http://www.lydsy.com/JudgeOnline/problem.php?id=1798 [题意] 给定一个序列,要求提供区间乘/加,以及区间求和的操作 [思路] 线段树 ...

随机推荐

  1. 关于functools模块的wraps装饰器用途

    测试环境:Python3.6.2 + win10 +  Pycharm2017.3 装饰器之functools模块的wraps的用途: 首先我们先写一个装饰器 # 探索functools模块wraps ...

  2. P2114 [NOI2014]起床困难综合症(二进制)

    P2114 [NOI2014]起床困难综合症 我们开始设俩数,一个二进制表示全是1,另一个全是0(就是2147483647 和 0 辣) 蓝后跑一遍门 于是最后有4种情况 1->0,1-> ...

  3. 阿里云端口失效导致tomcat无法对外提供服务

    下午,我们一个环境启动成功,但是却无法访问,经查看启动日志,如下: Mar 23, 2017 2:15:09 PM org.apache.coyote.http11.AbstractHttp11Pro ...

  4. sql xml 入门 (二)

    DECLARE @myDoc xml --http://www.paymob.cn --话费充值api,充值api,话费充值接口,手机话费充值,车贝手机,贝萌手机,移动话费充值,联通话费充值,电信话费 ...

  5. oracle常用SQL——创建用户、表空间、授权(12C)

    一.查询 查询用户所属 表空间 select username,default_tablespace from dba_users where username='xxx' 查询表空间情况 SELEC ...

  6. py4CV例子1猫狗大战和Knn算法

    1.什么是猫狗大战: 数据集来源于Kaggle(一个为开发商和数据科学家提供举办机器学习竞赛.托管数据库.编写和分享代码的平台),原数据集有12500只猫和12500只狗,分为训练.测试两个部分. 2 ...

  7. Python3 tkinter基础 Listbox Scrollbar 创建垂直滚动条

             Python : 3.7.0          OS : Ubuntu 18.04.1 LTS         IDE : PyCharm 2018.2.4       Conda ...

  8. [Sdoi2017]序列计数 矩阵优化dp

    题目 https://www.lydsy.com/JudgeOnline/problem.php?id=4818 思路 先考虑没有质数限制 dp是在同余系下的,所以\(f[i][j]\)表示前i个点, ...

  9. Win10 使用命令修复系统坏死点

    我的电脑win10系统升级多次以后,经常会出现所有设置有时点不开的情况 解决: C:\WINDOWS\system32>sfc /SCANNOW 开始系统扫描.此过程将需要一些时间. 开始系统扫 ...

  10. 【做题】arc068_f-Solitaire——糊结论

    把所有数字放入双端队列后,结果大概是这样一个排列: \[P_1 1 P_2\] 其中\(P_1\)是递减序列,\(P_2\)是递增序列. 我们以\(1\)所在的位置\(k\)分割最终的排列\(A\). ...