线段树模版

题目描述

如题,已知一个数列,你需要进行下面三种操作:

1.将某区间每一个数乘上x

2.将某区间每一个数加上x

3.求出某区间每一个数的和

输入输出格式

输入格式:

第一行包含三个整数N、M、P,分别表示该数列数字的个数、操作的总个数和模数。

第二行包含N个用空格分隔的整数,其中第i个数字表示数列第i项的初始值。

接下来M行每行包含3或4个整数,表示一个操作,具体如下:

操作1: 格式:1 x y k 含义:将区间[x,y]内每个数乘上k

操作2: 格式:2 x y k 含义:将区间[x,y]内每个数加上k

操作3: 格式:3 x y 含义:输出区间[x,y]内每个数的和对P取模所得的结果

输出格式:

输出包含若干行整数,即为所有操作3的结果。

输入输出样例

输入样例#1: 复制
5 5 38
1 5 4 2 3
2 1 4 1
3 2 5
1 2 4 2
2 3 5 5
3 1 4
输出样例#1: 复制
17
2

说明

时空限制:1000ms,128M

数据规模:

对于30%的数据:N<=8,M<=10

对于70%的数据:N<=1000,M<=10000

对于100%的数据:N<=100000,M<=100000

(数据已经过加强^_^)

样例说明:

故输出应为17、2(40 mod 38=2)






#include<bits/stdc++.h>
using namespace std;
#define maxn 100000+100000
#define LL long long
int mod;
LL tre[maxn<<2];
int a[maxn];
LL add[maxn<<2];
LL sub[maxn<<2];
void push(int in,int rt){
      sub[in*2]=1LL*sub[in*2]*sub[in]%mod;
      sub[in*2+1]=1LL*sub[in*2+1]*sub[in]%mod;
      add[in*2]=1LL*add[in*2]*sub[in]%mod;
      add[in*2+1]=1LL*add[in*2+1]*sub[in]%mod;
      tre[in*2]=1LL*tre[in*2]*sub[in]%mod;
      tre[in*2+1]=1LL*tre[in*2+1]*sub[in]%mod;
      sub[in]=1;
      add[in*2]=(add[in*2]+add[in])%mod;
      add[in*2+1]=(add[in*2+1]+add[in])%mod;
      tre[in*2]=(tre[in*2]+add[in]*(rt-rt/2)%mod)%mod;
      tre[in*2+1]=(tre[in*2+1]+add[in]*(rt/2)%mod)%mod;
      add[in]=0;
}
void build(int in,int l,int r){
   add[in]=0;
   sub[in]=1;
   if(l==r){
      tre[in]=a[l];
      return ;
   }
   int mid=(l+r)/2;
   build(in*2,l,mid);
   build(in*2+1,mid+1,r);
   tre[in]=(tre[in]+tre[in*2]+tre[in*2+1])%mod;
}
void updata(int in,int l,int r, int va,int x,int y,int i){
    push(in,y-x+1);
    if(l==x&&y==r){
        if(i==1){
            sub[in]=1LL*sub[in]*va%mod;
            tre[in]=1LL*tre[in]*va%mod;
        }
        if(i==2){
          add[in]+=va;
          add[in]%=mod;
          tre[in]+=((y-x+1)*va)%mod;
        }
        return ;
    }
    int mid=(x+y)/2;
    if(l>mid){
        updata(in*2+1,l,r,va,mid+1,y,i);
    }
    else if(r<=mid){
        updata(in*2,l,r,va,x,mid,i);
    }
    else{
        updata(in*2,l,mid,va,x,mid,i);
        updata(in*2+1,mid+1,r,va,mid+1,y,i);
    }
    tre[in]=(tre[in*2]+tre[in*2+1])%mod;
    tre[in]%=mod;

}
LL query(int in,int l,int r,int x,int y){
    push(in,y-x+1);
    if(l==x&&y==r){
        return tre[in]%mod;
    }

    int mid=(x+y)/2;
    if(l>mid){
        return query(in*2+1,l,r,mid+1,y)%mod;
    }
    else if(r<=mid){
        return query(in*2,l,r,x,mid)%mod;
    }
    else{
        return (query(in*2,l,mid,x,mid)%mod+query(in*2+1,mid+1,r,mid+1,y)%mod)%mod;
    }
}
int main(){
    int n,m;
    cin>>n>>m>>mod;
    for(int j=1;j<=n;j++){
       scanf("%d",&a[j]);
    }
    build(1,1,n);
    while(m--){
       int z,x,y,k;
       scanf("%d",&z);
       if(z==1||z==2){
        scanf("%d%d%d",&x,&y,&k);
        updata(1,x,y,k,1,n,z);
       }
       else {
          scanf("%d%d",&x,&y);
          cout<<query(1,x,y,1,n)%mod<<endl;
       }
    }

    return 0;
}

极简JAVA学习营第五期(报名以后加助教微信:eduxy-1)

01-19
想学好JAVA必须要报两万的培训班吗? 【课程背景】 JAVA是市场份额最大的编程语言,每天各大招聘网站上都会有数万个JAVA开发工程师的在招岗位,但是JAVA的技术体系庞大复杂,要想扎实掌握JAVA不是一件容易的事,线上学习相比线下两万起的高昂费用便宜了很多,而且具备学习时间灵活的优势,但是线上学习的劣势也很明显,没有线下那种学习氛围,碰到问题没法解决,在家学习很容易偷懒,极简JAVA学习营充分考虑到这些问题,通过每日实战编程练习,分队pk,助教答疑,作业点评,作业讲解,项目答辩等诸多环节充分激发你的学习热情,解决你学习中碰到的问题,让你花十分之一的钱学到JAVA的精髓,开启你的人生逆袭之路。 【专项的贴心服务】 1. 学练结合:定期布置视频任务和编程实战练习:通过每天的视频任务统一大家的进度,以便同学更好的交流,针对每天的任务会有相应的编程实战练习,通过练习内化知识。 2. 分队PK:将就业营的同学分成几队,通过作业统计表统计每队提交作业情况进行PK,激发你的学习动力。 3. 助教讲师答疑:碰到任何问题,发到群里,助教和讲师十分钟内帮你解决问题,扫清学习中的障碍。 4. 助教点评讲解作业:你每天提交作业都会有助教进行点评,让你知道有什么问题怎么解决,每三天一次视频讲解作业,互动解答问题 5. 项目答辩:每个阶段学完会有项目答辩,通过做项目巩固前一阶段的知识点,锻炼编码能力。 【往期训练营学习展示】 【套餐内容简介】 本套课以市场就业和职位需求为核心,从JAVA入门到多领域实战,设计出学习路线,共分为二十大模块,分别是:JAVA面向对象、Object类与常用API、集合框架、IO流、反射注解、多线程与网络编程、Object类与常用API等等。 同时采用理论讲解加实战演练的方式,既能让学员听懂听明白达到理解透彻,又能够在一个个真实实战案例中,让学员掌握真正有用的开发技能,从而进阶 JAVA 工程师! 套餐中一共包含21门JAVA程,助你从零进阶JAVA工程师! 阶段一:JAVA基础 课程1:《极简JAVA学习营开营篇》 课程2:《极简JAVA:JAVA面向对象》 课程3:《极简JAVA:Object类与常用API》 课程4:《极简JAVA:集合框架》 课程5:《极简JAVA:IO流》 课程6:《极简JAVA:反射注解》 课程7:《极简JAVA:多线程与网络编程》 阶段二:数据库入门 课程8:《极简JAVA:MySql数据库》 课程9:《极简JAVA:JDBC与连接池》 阶段三:JAVA WEB 课程10:《极简JAVA:HTML5与CSS3》 课程11:《极简JAVA:极简JAVA十一:Javascript与Jquery》 课程12:《极简JAVA:BootStrap》 课程13:《极简JAVA:JAVA Web》 阶段四:框架实战 课程14:《极简JAVA:Mavean入门》 课程15:《极简JAVA:MyBatis框架》 课程16:《极简JAVA:Spring框架》 课程17:《极简JAVA:Spring Mvc》 课程18:《极简JAVA:Oracle数据库》 课程19:《极简JAVA:Git入门》 课程20:《极简JAVA:Linux入门》 课程21:《极简JAVA:SpringBoot》 【课程特色】 1、易理解:讲师思路清晰、节奏明确、从易到难讲解透彻明白; 2、知识全:知识全面系统,从JAVA入门到实战,由易到难,让你彻底掌握JAVA开发; 3、重实战:涵盖大量实战项目,锻炼你的动手实操能力,面向工作编程; 【面向人群】 1、在校计算机专业或者对软件编程感兴趣的学生; 2、零基础想学JAVA却不知道从何入手 3、囊中羞涩,面对两万起的JAVA培训班不忍直视 4、在职没有每天大块的时间专门学习JAVA 这么细致的服务,这么好的氛围,这样的学习效果,你还等什么?赶紧报名吧,抓紧抢位,本期只招100人,错过只有等时间待定的下一期了
©️2020 CSDN 皮肤主题: 编程工作室 设计师: CSDN官方博客 返回首页
实付0元
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、C币套餐、付费专栏及课程。

余额充值