题目链接

P2023 [AHOI2009]维护序列

解题思路

线段树板子。不难,但是...有坑。坑有多深?一页\(WA\)。

由于乘法可能乘\(k=0\),我这种做法可能会使结果产生负数。于是就有了这篇题解。

(详情见代码注释)

AC代码

#include<stdio.h>
#define min(a,b) (a>b?b:a)
#define max(a,b) (a>b?a:b)
typedef long long ll;
int n,m;
ll mod,k,a[500010];
struct Tree{
int left,right;
ll data,lazy,mul;
}tree[2000010];
void build(int p,int left,int right){
tree[p].left=left;
tree[p].right=right;
tree[p].mul=1;
if(left==right){tree[p].data=a[left];return;}
build(p<<1,left,(left+right)>>1);
build(p<<1|1,((left+right)>>1)+1,right);
tree[p].data=(tree[p<<1].data+tree[p<<1|1].data)%mod;
}
void pushdown(int p){
ll mul=tree[p].mul,lazy=tree[p].lazy;
tree[p<<1].lazy*=mul;
tree[p<<1].lazy+=lazy;tree[p<<1].lazy%=mod;
tree[p<<1].mul*=mul;tree[p<<1].mul%=mod;
tree[p<<1|1].lazy*=mul;
tree[p<<1|1].lazy+=lazy;tree[p<<1|1].lazy%=mod;
tree[p<<1|1].mul*=mul;tree[p<<1|1].mul%=mod;
tree[p].data*=tree[p].mul;
tree[p].data+=(tree[p].right-tree[p].left+1)*tree[p].lazy;
tree[p].data%=mod;
tree[p].lazy=0;tree[p].mul=1;
}
void add(int left,int right,ll k,int p){
int l=tree[p].left,r=tree[p].right;
if(l>right||r<left||p>4*n)return;
pushdown(p);
if(l>=left&&r<=right){
tree[p].lazy+=k;
tree[p].lazy%=mod;
return;
}
tree[p].data+=k*(min(right,r)-max(left,l)+1);
tree[p].data%=mod;
add(left,right,k,p<<1);
add(left,right,k,p<<1|1);
}
ll multy(int left,int right,ll k,int p){
int l=tree[p].left,r=tree[p].right;
if(l>right||r<left||p>4*n)return 0;
pushdown(p);
if(l>=left&&r<=right){
ll temp=tree[p].data*tree[p].mul+tree[p].lazy*(r-l+1);
tree[p].lazy*=k;tree[p].lazy%=mod;
tree[p].mul*=k;tree[p].mul%=mod;
return ((k-1)*temp%mod+mod)%mod;//非常重要!!!!!!
}
ll temp=multy(left,right,k,p<<1)+multy(left,right,k,p<<1|1);
tree[p].data+=temp;
tree[p].data=;
return temp;
}
ll query(int left,int right,int p){
int l=tree[p].left,r=tree[p].right;
if(l>right||r<left||p>4*n)return 0;
pushdown(p);
if(l>=left&&r<=right)return tree[p].data;
return query(left,right,p<<1)+query(left,right,p<<1|1);
}
int main(){
int s,x,y,i;
scanf("%d%lld",&n,&mod);
for(i=1;i<=n;i++)scanf("%lld",&a[i]);
build(1,1,n);
scanf("%d",&m);
while(m--){
scanf("%d%d%d",&s,&x,&y);
if(s-3){
scanf("%lld",&k);
if(s-1)add(x,y,k,1);
else multy(x,y,k,1);
}else printf("%lld\n",query(x,y,1)%mod);
}
return 0;
}

P2023 [AHOI2009]维护序列 题解(线段树)的更多相关文章

  1. 洛谷P2023 [AHOI2009]维护序列(线段树区间更新,区间查询)

    洛谷P2023 [AHOI2009]维护序列 区间修改 当我们要修改一个区间时,要保证 \(ax+b\) 的形式,即先乘后加的形式.当将区间乘以一个数 \(k\) 时,原来的区间和为 \(ax+b\) ...

  2. 【题解】洛谷P2023 [AHOI2009] 维护序列(线段树)

    洛谷P2023:https://www.luogu.org/problemnew/show/P2023 思路 需要2个Lazy-Tag 一个表示加的 一个表示乘的 需要先计算乘法 再计算加法 来自你谷 ...

  3. BZOJ_1798_[AHOI2009]维护序列_线段树

    BZOJ_1798_[AHOI2009]维护序列_线段树 题意:老师交给小可可一个维护数列的任务,现在小可可希望你来帮他完成. 有长为N的数列,不妨设为a1,a2,…,aN .有如下三种操作形式: ( ...

  4. 洛谷P3373 【模板】线段树 2 && P2023 [AHOI2009]维护序列——题解

    题目传送: P3373 [模板]线段树 2  P2023 [AHOI2009]维护序列 该题较传统线段树模板相比多了一个区间乘的操作.一提到线段树的区间维护问题,就自然想到了“懒标记”:为了降低时间复 ...

  5. 洛谷 P2023 [AHOI2009]维护序列 题解

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

  6. 1798. [AHOI2009]维护序列【线段树】

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

  7. 洛谷 P2023 [AHOI2009]维护序列

    P2023 [AHOI2009]维护序列 题目描述 老师交给小可可一个维护数列的任务,现在小可可希望你来帮他完成. 有长为N的数列,不妨设为a1,a2,…,aN .有如下三种操作形式: (1)把数列中 ...

  8. 【bzoj1798】[Ahoi2009]Seq 维护序列seq 线段树

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

  9. [洛谷P2023] [AHOI2009]维护序列

    洛谷题目链接:[AHOI2009]维护序列 题目描述 老师交给小可可一个维护数列的任务,现在小可可希望你来帮他完成. 有长为N的数列,不妨设为a1,a2,-,aN .有如下三种操作形式: (1)把数列 ...

随机推荐

  1. 8.rabbitmq RPC模拟微服务架构中的服务调用

    标题 : 8.rabbitmq RPC模拟微服务架构中的服务调用 目录 : RabbitMQ 序号 : 8 { var connectionFactory = new ConnectionFactor ...

  2. KEIL5 使用STM32 官方例程

    1. 安装keil5,破解 网上很多安装包/教程,跳过 2.下载官方固件库 https://www.st.com/content/st_com/en.html 在这里找微处理器,STM32 stand ...

  3. mybatis(十一)mybatis常见问题

    用注解还是用 xml 配置? 常用注解:@Insert.@Select.@Update.@Delete.@Param.@Results. @Result 在 MyBatis 的工程中,我们有两种配置 ...

  4. set CSS style in js solutions All In One

    set CSS style in js solutions All In One css in js set each style property separately See the Pen se ...

  5. 高阶函数 HOF & 高阶组件 HOC

    高阶函数 HOF & 高阶组件 HOC 高阶类 js HOC 高阶函数 HOF 函数作为参数 函数作为返回值 "use strict"; /** * * @author x ...

  6. CSS3 & Grid Layout All In One

    CSS3 & Grid Layout All In One W3C https://www.w3.org/TR/css-grid-1/ Grid Layout is a new layout ...

  7. ts 遍历Class上的属性和方法

    interface Type<T> extends Function { new (...args: any[]): T; } class Data { name = "ajan ...

  8. 200万枚SPC空投来袭,这样的薅羊毛活动你确定不参加吗?

    在过去的2020年,币圈真的是很火爆,很多人在参与数字货币交易或DeFi挖矿中赚到了大钱.但是转眼到了2021年,DeFi进入了下半场,区块链市场也进入了新的阶段,那么区块链的下一个爆点是什么呢?很多 ...

  9. PAUL ADAMS ARCHITECT:爱丁堡的房屋价值创历史新高

    近日,英国知名房产公司保罗·亚当斯公司根据一组调查报告表示,今年第三季度,爱丁堡的房价再创历史新高,并向大家分析了原因. 保罗·亚当斯公司(公司编号:07635831)是英国一家著名的房地产公司,总部 ...

  10. django学习-4.url动态传值

    1.前言 我们在浏览器访问一个网页A是通过一个指定的url地址去访问的.但在浏览器用一个不存在的url地址去执行访问是打不开正确的网页的,只会打开一个浏览器自带的有错误提示的网页. 在django框架 ...