题目大意:维护一个序列,提供三种操作:

1.将区间中每个点的权值乘上一个数

2.将区间中每个点的权值加上一个数

3.求一段区间的和对p取模的值

2631的超^n级弱化版。写2631之前能够拿这个练练手。。。

线段树区间改动,让学校的大神指导了一下ZKW的区间改动方法,非常好理解,可是代码还是快不了。

回头再改改代码吧 可能是我写的太渣了

#include<cstdio>
#include<cstring>
#include<iostream>
#include<algorithm>
#define M 100100
using namespace std;
typedef long long ll;
struct abcd{
ll sum,siz,add_mark,times_mark;
void add(ll x);
void times(ll x);
}tree[263000];
int m,n,p,q;
void abcd :: add(ll x)
{
sum+=x*siz;
sum%=p;
add_mark+=x;
add_mark%=p;
}
void abcd :: times(ll x)
{
sum*=x;
sum%=p;
add_mark*=x;
add_mark%=p;
times_mark*=x;
times_mark%=p;
}
void Build_Tree()
{
int i;
for(i=q+1;i<=q+n;i++)
{
scanf("%d",&tree[i].sum);
tree[i].siz=1;
tree[i].add_mark=0;
tree[i].times_mark=1;
}
for(i=q-1;i;i--)
{
tree[i].sum=tree[i<<1].sum+tree[i<<1|1].sum;
tree[i].sum%=p;
tree[i].siz=tree[i<<1].siz+tree[i<<1|1].siz;
tree[i].add_mark=0;
tree[i].times_mark=1;
}
}
int stack[M],top;
void Push_Down(int x)
{
if(x>=q)
return ;
if(tree[x].times_mark^1)
{
tree[x<<1 ].times(tree[x].times_mark);
tree[x<<1|1].times(tree[x].times_mark);
tree[x].times_mark=1;
}
if(tree[x].add_mark)
{
tree[x<<1 ].add(tree[x].add_mark);
tree[x<<1|1].add(tree[x].add_mark);
tree[x].add_mark=0;
}
}
void Push_Down(int x,int y)
{
for(x+=q-1,y+=q+1;x^y;x>>=1,y>>=1)
stack[++top]=x,stack[++top]=y;
for(;x;x>>=1)
stack[++top]=x;
while(top)
Push_Down(stack[top--]);
}
void Add(int x,int y,ll z)
{
for(x+=q-1,y+=q+1;x^y^1;x>>=1,y>>=1)
{
if(~x&1)tree[x^1].add(z);
if( y&1)tree[y^1].add(z);
}
}
void Times(int x,int y,ll z)
{
for(x+=q-1,y+=q+1;x^y^1;x>>=1,y>>=1)
{
if(~x&1)tree[x^1].times(z);
if( y&1)tree[y^1].times(z);
}
}
void Push_Up(int x)
{
if(x>=q)
return ;
tree[x].sum=tree[x<<1].sum+tree[x<<1|1].sum;
tree[x].sum%=p;
}
void Push_Up(int x,int y)
{
for(x+=q-1,y+=q+1;x^y;x>>=1,y>>=1)
Push_Up(x),Push_Up(y);
for(;x;x>>=1)
Push_Up(x);
}
ll Get_Ans(int x,int y)
{
int re=0;
for(x+=q-1,y+=q+1;x^y^1;x>>=1,y>>=1)
{
if(~x&1)re+=tree[x^1].sum,re%=p;
if( y&1)re+=tree[y^1].sum,re%=p;
}
return re;
}
int main()
{
int i,x,y,c;
ll z;
cin>>n>>p;
for(q=1;q<=n+1;q<<=1);
Build_Tree();
cin>>m;
for(i=1;i<=m;i++)
{
scanf("%d",&c);
if(c==1)
{
scanf("%d%d%lld",&x,&y,&z);
Push_Down(x,y);
Times(x,y,z);
Push_Up(x,y);
}
else if(c==2)
{
scanf("%d%d%lld",&x,&y,&z);
Push_Down(x,y);
Add(x,y,z);
Push_Up(x,y);
}
else
{
scanf("%d%d",&x,&y);
Push_Down(x,y);
printf("%lld\n", Get_Ans(x,y) );
}
}
}

BZOJ 1798 AHOI2009 Seq 维护序列 线段树的更多相关文章

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

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

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

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

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

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

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

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

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

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

  6. bzoj 1798 [Ahoi2009]Seq 维护序列seq

    原题链接:http://www.lydsy.com/JudgeOnline/problem.php?id=1798 线段树区间更新: 1. 区间同同时加上一个数 2. 区间同时乘以一个数 #inclu ...

  7. [BZOJ1798][AHOI2009]Seq维护序列 线段树

    题目链接:http://www.lydsy.com/JudgeOnline/problem.php?id=1798 一眼看过去线段树,事实上就是线段树.对于乘和加的两个标记,我们可以规定一个顺序,比如 ...

  8. bzoj 1798 [Ahoi2009]Seq 维护序列seq ——线段树

    题目:https://www.lydsy.com/JudgeOnline/problem.php?id=1798 先乘后加,就可给加法标记乘上乘法标记. 注意可能有 *0 的操作,所以 pshd 时不 ...

  9. BZOJ 1798: [Ahoi2009]Seq 维护序列seq (线段树乘法加法的混合操作)

     题目:点击打开链接 大意:一个数组.三个操作.第一种是区间[a,b]每一个数乘乘,另外一种是区间[a,b]每一个数加c,第三种是查询[a,b]区间的和并对p取摸. 两种操作就不能简单的仅仅往下传 ...

随机推荐

  1. Java学习笔记(6)

    java是面向对象的语言. 对象:真实存在的唯一的事物. 类:实际就是对某种类型事物的共性属性与行为的抽取 面向对象的计算机语言的核心思想:找适合的对象做适合的事情. 如何找适合的对象呢: 1.sun ...

  2. Swift中的GCD——常见的dispatch方法

    什么是GCD Grand Central Dispatch (GCD)是Apple开发的一个多核编程的解决方法.该方法在Mac OS X 10.6雪豹中首次推出,并随后被引入到了iOS4.0中.GCD ...

  3. 移动端与PHP服务端接口通信流程设计(增强版)

    前面讲过:移动端与PHP服务端接口通信流程设计(基础版) 对于 api_token 的校验,其安全性还可再增强: 增强地方一: 再增加2张表,一个接口表,一个授权表,设计参考如下: 接口表 字段名 字 ...

  4. JavaScript 中函数节流和函数去抖的讲解

    JavaScript 中函数节流和函数去抖的讲解 我们都知道频繁触发执行一段js逻辑代码对性能会有很大的影响,尤其是在做一些效果实现方面,或者逻辑中需要进行后端请求,更是会导致卡顿,效果失效等结果,所 ...

  5. [PATCH] ARM: add dtbImage.<dt> and dtbuImage.<dt> rules

    转载: http://permalink.gmane.org/gmane.linux.kbuild.devel/8755 This rules are useful for appended devi ...

  6. Sql-简单分页

    create proc proc_searchuser( @username varchar(12), @page int=1, @pagesize int=3, @totalcount int ou ...

  7. WebLogic Server 关键优化指标

    昨天给客户做巡检,又将整个WebLogic Server的优化过程走了一遍,记录下来给大家参考. 1.JVM优化 查看 $ps –ef | grep java /opt/java1.5/bin/jav ...

  8. MariaDB数据库管理系统

    MYSQL数据库管理系统被Oracle公司收购后从开源换向到了封闭,导致许多Linux发行版选择了MariaDB.   MYSQL是一款大家都非常熟知的数据库管理系统,技术成熟.配置简单.开源免费并且 ...

  9. Less 简介

    什么是LESSCSS LESSCSS是一种动态样式语言,属于CSS预处理语言的一种,它使用类似CSS的语法,为CSS的赋予了动态语言的特性,如变量.继承.运算.函数等,更方便CSS的编写和维护. LE ...

  10. scrapy-splash抓取动态数据例子十二

    一.介绍 本例子用scrapy-splash通过搜狗搜索引擎,输入给定关键字抓取资讯信息. 给定关键字:数字:融合:电视 抓取信息内如下: 1.资讯标题 2.资讯链接 3.资讯时间 4.资讯来源 二. ...