BZOJ1798: [Ahoi2009]Seq 维护序列seq
写这道题是为了get一个同时传送乘法下标和加法下标的小技巧,线段树模板题。不多说。
标记名字打错无限智力--
//BZOJ 1798
//by Cydiater
//2016.9.13
#include <iostream>
#include <cstdio>
#include <cstring>
#include <string>
#include <algorithm>
#include <queue>
#include <map>
#include <iomanip>
#include <cstdlib>
#include <cmath>
#include <ctime>
using namespace std;
#define ll unsigned long long
#define up(i,j,n) for(int i=j;i<=n;i++)
#define down(i,j,n) for(int i=j;i>=n;i--)
#define FILE "seqb"
;
const ll oo=0x3f3f3f3f;
inline ll read(){
,f=;
;ch=getchar();}
+ch-';ch=getchar();}
return x*f;
}
struct SegTree{
ll v,delta1,delta2,leftt,rightt;
}t[MAXN<<];
ll N,mod,M,op,x,y,Delta1,Delta2,a[MAXN];
namespace solution{
inline void downit(int node){
if(t[node].leftt==t[node].rightt)return;
ll delta1=t[node].delta1,delta2=t[node].delta2,leftt,rightt;
t[node].delta1=;t[node].delta2=;
){
t[node<<].delta1*=delta2;t[node<<].delta1%=mod;
t[node<<].delta2*=delta2;t[node<<].delta2%=mod;
t[node<<].v*=delta2;t[node<<].delta2%=mod;
t[node<<|].delta1*=delta2;t[node<<|].delta1%=mod;
t[node<<|].delta2*=delta2;t[node<<|].delta2%=mod;
t[node<<|].v*=delta2;t[node<<|].delta2%=mod;
}
leftt=t[node<<].leftt;rightt=t[node<<].rightt;
t[node<<].delta1+=delta1;t[node<<].delta1%=mod;
t[node<<].v+=(rightt-leftt+)*delta1;t[node<<].v%=mod;
leftt=t[node<<|].leftt;rightt=t[node<<|].rightt;
t[node<<|].delta1+=delta1;t[node<<|].delta1%=mod;
t[node<<|].v+=(rightt-leftt+)*delta1;t[node<<|].v%=mod;
}
inline ].v+t[node<<|].v)%mod;}
inline void updata(int leftt,int rightt,int root){
downit(root);
if(leftt>y||rightt<x) return;
if(leftt>=x&&rightt<=y){
if(Delta1){
t[root].delta1+=Delta1;
t[root].v+=(rightt-leftt+)*Delta1;
t[root].delta1%=mod;
t[root].v%=mod;
}
){
t[root].delta1*=Delta2;t[root].delta1%=mod;
t[root].delta2*=Delta2;t[root].delta2%=mod;
t[root].v*=Delta2;t[root].v%=mod;
}
return;
}
;
updata(leftt,mid,root<<);
updata(mid+,rightt,root<<|);
reload(root);
}
inline ll find(int leftt,int rightt,int root){
downit(root);
;
if(leftt>=x&&rightt<=y) return t[root].v;
;
)+find(mid+,rightt,root<<|))%mod;
}
inline void build(int leftt,int rightt,int root){
t[root].delta2=;
if(leftt==rightt){
t[root].leftt=t[root].rightt=leftt;
t[root].v=a[leftt];t[root].delta1=;
return;
}
t[root].leftt=leftt;t[root].rightt=rightt;t[root].delta1=;
;
build(leftt,mid,root<<);
build(mid+,rightt,root<<|);
reload(root);
}
void slove(){
N=read();mod=read();
up(i,,N)a[i]=read();
build(,N,);
M=read();
while(M--){
op=read();x=read();y=read();
){
Delta1=;Delta2=read();
updata(,N,);
}
){
Delta1=read();Delta2=;
updata(,N,);
}
){
printf(,N,));
//cout<<find(1,N,1)<<endl;
}
}
}
}
int main(){
//freopen(FILE".in","r",stdin);
//freopen("input.in","r",stdin);
//freopen(FILE".out","w",stdout);
using namespace solution;
slove();
;
}
BZOJ1798: [Ahoi2009]Seq 维护序列seq的更多相关文章
- BZOJ1798: [Ahoi2009]Seq 维护序列seq[线段树]
1798: [Ahoi2009]Seq 维护序列seq Time Limit: 30 Sec Memory Limit: 64 MBSubmit: 5504 Solved: 1937[Submit ...
- BZOJ 1798: [Ahoi2009]Seq 维护序列seq( 线段树 )
线段树.. 打个 mul , add 的标记就好了.. 这个速度好像还挺快的...( 相比我其他代码 = = ) 好像是#35.. ---------------------------------- ...
- 1798: [Ahoi2009]Seq 维护序列seq
1798: [Ahoi2009]Seq 维护序列seq Time Limit: 30 Sec Memory Limit: 64 MBSubmit: 2930 Solved: 1087[Submit ...
- bzoj 1798: [Ahoi2009]Seq 维护序列seq (线段树 ,多重标记下放)
1798: [Ahoi2009]Seq 维护序列seq Time Limit: 30 Sec Memory Limit: 64 MBSubmit: 7773 Solved: 2792[Submit ...
- bzoj 1798: [Ahoi2009]Seq 维护序列seq 线段树 区间乘法区间加法 区间求和
1798: [Ahoi2009]Seq 维护序列seq Time Limit: 1 Sec Memory Limit: 256 MB 题目连接 http://www.lydsy.com/JudgeO ...
- Bzoj 1798: [Ahoi2009]Seq 维护序列seq(线段树区间操作)
1798: [Ahoi2009]Seq 维护序列seq Time Limit: 30 Sec Memory Limit: 64 MB Description 老师交给小可可一个维护数列的任务,现在小可 ...
- BZOJ1798[Ahoi2009]Seq 维护序列seq 题解
题目大意: 有长为N的数列,有如下三种操作形式: (1)把数列中的一段数全部乘一个值; (2)把数列中的一段数全部加一个值; (3)询问数列中的一段数的和,由于答案可能很大,你只需输出这个数模P的值. ...
- 【bzoj1798】[Ahoi2009]Seq 维护序列seq 线段树
题目描述 老师交给小可可一个维护数列的任务,现在小可可希望你来帮他完成. 有长为N的数列,不妨设为a1,a2,…,aN .有如下三种操作形式: (1)把数列中的一段数全部乘一个值; (2)把数列中的一 ...
- 【分块】bzoj1798 [Ahoi2009]Seq 维护序列seq
分块,打标记,维护两个标记:乘的 和 加的. 每次 区间乘的时候,对 乘标记 和 加标记 都 乘上那个值. 每次 区间加的时候 对 加标记 加上那个值. (ax+b)*v=axv+bv.开 long ...
- [bzoj1798][Ahoi2009]Seq 维护序列seq ([洛谷P3373]【模板】线段树 2)
题目大意:有$n$个数,有$m$个操作,有三种: $1\;l\;r\;x:$把区间$[l,r]$内的数乘上$x$ $2\;l\;r\;x:$把区间$[l,r]$内的数加上$x$ $3\;l\;r:$询 ...
随机推荐
- 用 Linux自带的logrotate 来管理日志
大家可能都有管理日志的需要,比如定时压缩日志,或者当日志超过一定大小时就自动分裂成两个文件等.最近就接到这样一个小任务.我们的程序用的是C语言,用log4cpp的library来实现日志记录.但是问题 ...
- centos7 安装nginx和php5.6.25遇到 无法访问php页面 报错file not found 问题解决
php-fpm安装完成,nginx安装完成 netstap -ntl| 发下端口正常开启 iptables -L 返现9000端口已经开放 ps -aux|grep nginx 发下nginx进程正常 ...
- Android闹钟设置的解决方案
Android设置闹钟并不像IOS那样这么简单,做过Android设置闹钟的开发者都知道里面的坑有多深.下面记录一下,我解决Android闹钟设置的解决方案. 主要问题 API19开始AlarmMan ...
- ASP.NET 返回字符串 IE6乱码问题
项目A,所有的文件编码和内容编码都是UTF-8. 项目B,Index.aspx文件编码和页面内容编码都是GB2312. 项目A返回JSON格式数据给项目B时,其它浏览器都可以就是IE不行.后来在网上找 ...
- ubuntu14.04 安装配置JDK1.7
1,下载jdk-7u45-linux-x64.tar.gz 网址:http://www.oracle.com/technetwork/java/javase/downloads/jdk7-downlo ...
- iOS开发小技巧--学会包装控件(有些view的位置由于代码或系统原因,位置或者尺寸不容易修改或者容易受外界影响)
一.百思项目中遇到了两处这样的问题, 第一处 - 是评论界面的headerView,由于直接把自己搞的xib加载了放在了那里,xib中setFrame写了好多-= +=,每次滚动的时候,会频繁调用x ...
- 02python算法-递推
递推 1什么是递推?:根据已有节点的值,以及规律推出之后节点的值 2为什么要用递推:简单的解决有规矩事件 3怎么用?: 我们举个经典的例子: 如果1对兔子每月能生1对小兔子,而每对小兔在它出生后的第3 ...
- Visual Studio 2015正式版/产品密钥
Visual Studio 2015 发行说明: https://visualstudio.com/zh-cn/news/vs2015-vs.aspx Visual Studio 2015 特性简 ...
- 快速查找无序数组中的第K大数?
1.题目分析: 查找无序数组中的第K大数,直观感觉便是先排好序再找到下标为K-1的元素,时间复杂度O(NlgN).在此,我们想探索是否存在时间复杂度 < O(NlgN),而且近似等于O(N)的高 ...
- iOS开发基础知识碎片
1:contentSize.contentInset和contentOffset区别 contentSize 是scrollview中的一个属性,它代表scrollview中的可显示区域,假如有一个s ...