线段树维护两个标记。

*0的操作在实质上没有任何影响。

#include <cstdio>
#include <cctype>

#define rep(i,a,b) for (int i=(a);i<=(b);i++)

#define LL long long

#define lc (x<<1)
#define rc (x<<1|1)
#define siz(x) (tr[x].r-tr[x].l+1)

const int N=131072;
const int S=262144;

int n,p,m,a[N];
struct Tree {
    int l,r;
    int a,b;        //tag(a,b): ax+b
    int sum;
    Tree(int _l=0,int _r=0) {
        l=_l,r=_r;
        a=1,b=0;
        sum=0;
    }
}tr[S];

int rd(void) {
    int x=0,f=1; char c=getchar();
    while (!isdigit(c)) {
        if (c=='-') f=-1;
        c=getchar();
    }
    while (isdigit(c)) {
        x=x*10+c-'0';
        c=getchar();
    }
    return x*f;
}

void Pushup(int x) {
    tr[x].sum=(tr[lc].sum+tr[rc].sum)%p;
}

void Clear(int x) {
    int a=tr[x].a,b=tr[x].b; if (a==1&&!b) return; tr[x].a=1,tr[x].b=0;
    tr[lc].sum=((LL)a*tr[lc].sum+(LL)b*siz(lc))%p; tr[lc].a=(LL)a*tr[lc].a%p; tr[lc].b=((LL)a*tr[lc].b+b)%p;
    tr[rc].sum=((LL)a*tr[rc].sum+(LL)b*siz(rc))%p; tr[rc].a=(LL)a*tr[rc].a%p; tr[rc].b=((LL)a*tr[rc].b+b)%p;
}

void Build(int x,int l,int r) {
    tr[x]=Tree(l,r);
    if (l!=r) {
        int mid=(l+r)>>1;
        Build(lc,l,mid);
        Build(rc,mid+1,r);
        Pushup(x);
    }
    else tr[x].sum=a[l];
}

void Modify(int x,int l,int r,int a,int b) {
    if (l<=tr[x].l&&tr[x].r<=r) {
        tr[x].sum=((LL)a*tr[x].sum+(LL)b*siz(x))%p;
        tr[x].a=(LL)a*tr[x].a%p;
        tr[x].b=((LL)a*tr[x].b+b)%p;
        return;
    }
    Clear(x);
    int mid=(tr[x].l+tr[x].r)>>1;
    if (l<=mid)
        Modify(lc,l,r,a,b);
    if (mid<r)
        Modify(rc,l,r,a,b);
    Pushup(x);
}

int Query(int x,int l,int r) {
    if (l<=tr[x].l&&tr[x].r<=r) return tr[x].sum;
    Clear(x);
    int sum=0; int mid=(tr[x].l+tr[x].r)>>1;
    if (l<=mid) {
        int t=Query(lc,l,r);
        sum=(sum+t)%p;
    }
    if (mid<r) {
        int t=Query(rc,l,r);
        sum=(sum+t)%p;
    }
    return sum;
}

int main(void) {
    #ifndef ONLINE_JUDGE
    freopen("sd.in","r",stdin);
    freopen("sd.out","w",stdout);
    #endif

    n=rd(),p=rd();
    rep(i,1,n) a[i]=rd();
    Build(1,1,n);

    m=rd();
    rep(i,1,m) {
        int kd=rd(); int x,y,z;
        switch (kd) {
            case 1:
                x=rd(),y=rd(),z=rd();
                Modify(1,x,y,z,0);
                break;
            case 2:
                x=rd(),y=rd(),z=rd();
                Modify(1,x,y,1,z);
                break;
            case 3:
                x=rd(),y=rd();
                int res=Query(1,x,y);
                printf("%d\n",res);
                break;
        }
    }

    return 0;
}

【bzoj1798】维护序列的更多相关文章

  1. BZOJ1798 维护序列seq

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

  2. 【双标记线段树】bzoj1798维护序列seq

    一.题目 描述 老师交给小可可一个维护数列的任务,现在小可可希望你来帮他完成. 有长为N的数列,不妨设为a1,a2,-,aN .有如下三种操作形式: (1)把数列中的一段数全部乘一个值; (2)把数列 ...

  3. bzoj1798 维护序列

    Description 老师交给小可可一个维护数列的任务,现在小可可希望你来帮他完成. 有长为N的数列,不妨设为a1,a2,…,aN .有如下三种操作形式: (1)把数列中的一段数全部乘一个值; (2 ...

  4. p2023&bzoj1798 维护序列

    传送门(洛谷) 传送门(bzoj) 题目 老师交给小可可一个维护数列的任务,现在小可可希望你来帮他完成. 有长为N的数列,不妨设为a1,a2,…,aN .有如下三种操作形式: (1)把数列中的一段数全 ...

  5. bzoj1798维护序列

    题目链接 暴力数据结构之线段树$qwq$ 裸题直接敲板子 忘了啥时候写的了$qwq$ 直接上代码吧 /************************************************* ...

  6. BZOJ-1798 维护序列

    线段树.支持区间加.区间乘.区间查询和. 标记下移还有取模要注意. var n,p,q,i,s,t:longint; a:int64; num,n1,n2,n3:array[0..500000] of ...

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

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

  8. [AHOI 2009] 维护序列(线段树模板题)

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

  9. bzoj 维护序列seq(双标记线段树)

    Seq 维护序列seq Time Limit: 30 Sec  Memory Limit: 64 MBSubmit: 4184  Solved: 1518[Submit][Status][Discus ...

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

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

随机推荐

  1. Android的onMeasure和onLayout And MeasureSpec揭秘

    Android中自定义ViewGroup最重要的就是onMeasure和onLayout方法,都需要重写这两个方法,ViewGroup绘制 的过程是这样的:onMeasure → onLayout → ...

  2. 对于指定区块div,如何区分区块内的点击 和 区块外的点击?

    需求:对于区块div内点击事件, 需要展示区块内的附属操作区块,对于区块外的点击, 需要将前面说的附属操作区块隐藏掉. 分析:对于一般的HTML控件,有标准的js事件接口, focus和blur,来实 ...

  3. RDIFramework.NET ━ .NET快速信息化系统开发框架钜献 V2.9 版本震撼发布

    RDIFramework.NET ━ .NET快速信息化系统开发框架钜献 V2.9 版本震撼发布 全新体验.全新感觉.2015钜献! 继上个版本“RDIFramework.NET V2.8版本发布”5 ...

  4. java虚拟机内部介绍

    一.介绍 java 的内存管理和垃圾回收在某种程度是同一个问题来着.对于java程序员来说,在虚拟机自动内存管理机制的帮助下,不在需要为每一个new操作去写配对的delete/free代码,不容易出现 ...

  5. session跟cookies区别

    Session和Cookie的使用总结: Session和cookie都是asp.Net中的内置对象,至于他们有什么区别,在这里就不在多说,现在来说说一些比较实用点的东西: 我们知道网站都有一个后台管 ...

  6. AppleWatch___学习笔记(三)iPhone和Apple Watch上的数据同步

    WatchKit App类似于之前iOS 8上新推出的App Extension(应用扩展),比如Today Extension(今天扩展)和Share Extension(分享扩展).只要你对iOS ...

  7. 重新安装了mysql,以前的数据库如何导入到新的数据库

    重新安装了mysql,以前的数据库如何导入到新的数据库,导入到新的数据库不能用真么办? 将之前的mysql中的data目录中的数据库文件夹,(需要哪个数据库复制哪个,不要都复制) D:/wamp/bi ...

  8. IE8 下 select option 内容过长 , 展开时信息显示不全解决办法

    IE8 下 select option 内容过长 , 展开时信息显示不全 , 简单折衷的方式就是给 option 加上 title 属性 , 但是又不想一个个的修改,怎么办呢,代码如下 : //sel ...

  9. openDatabase() chrome vivaldi Stylish

    located at /Users/ruili/Library/Application Support/Vivaldi/Default/databases/ Databases.db contains ...

  10. WPF:常见问题

    1.自定义Main函数 背景: wpf 默认的Main函数在 App.g.cs文件中,在App.xmal.cs内自定义Main函数后冲突. 解决方法: 法一: 1)新建class1.cs类,在其中设置 ...