题目链接

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. 解决关闭ssh后网页停止服务的方法,利用nohup

    上一篇文章提到宝塔面板无法运行,只能用ssh运行app.py. 关闭ssh时,app.py会被杀死.因为app.py的父进程就是ssh,关掉ssh会造成进程被杀死. 解决方法参考  https://w ...

  2. ffmpeg开发环境搭建--(linux)

    1.     下载源码: http://ffmpeg.org/download.html 2.     解压:tar –xvf ffmpeg-3.2.1.tar.bz2 3.     配置 Eg:./ ...

  3. MarkDown(文本编译器)

    MarkDown(一种高效的文本编译器) 推荐使用Typora 点击此处下载 使用方法 1. 首先创建一个文本文件xxx.txt. 2. 然后修改文件后缀为xxx.md.(可以记做玛德...) 3. ...

  4. 属于我的md5sum程序

    目录 前言 介绍 使用说明 总结 前言 之所以想做这个软件是因为一直在使用的http://keir.net/hash.html软件有很多功能不能满足. 经过自学C#,研究多线程,异步更新UI,等等知识 ...

  5. vue component :is

    vue component :is Vue <component> element https://vuejs.org/v2/guide/components.html#Dynamic-C ...

  6. free food icons

    free food icons food icons Chinese foods https://www.flaticon.com/categories/food-and-restaurant htt ...

  7. how to delete the virtual dom that created in memory using js

    how to delete the virtual dom that created in memory using js const virtualDomConvert = (filename = ...

  8. H5 & animation

    H5 & animation https://m.tb.cn/h.VYB7BAx?sm=51fda6 UA checker webp image & css animation CDN ...

  9. perl 打印目录结构

    更多 #!/usr/bin/perl # 递归打印目录结构 use v5.26; use strict; use utf8; use autodie; use warnings; use Encode ...

  10. NGK与AOFEX交易所达成战略合作,BGV即将上线A网!

    据NGK官方消息,NGK官方已经与英国伦敦知名交易所AOFEX交易所达成战略合作,将于12月2日全球首发BGV,现已开启充值服务.同时,在12月3日15:00,用户可以参与BGV交易:在12月4日15 ...