AC日记——[Ahoi2009]Seq 维护序列seq bzoj 1798
思路:
维护两个标记;
乘:m 和 加:a
先下放乘,再下放加;
下放乘的时候要把子节点的加一块乘了;
开long long;
来,上代码:
#include <cstdio>
#include <cstring>
#include <iostream>
#include <algorithm> using namespace std; #define maxn 100005
#define ll long long struct TreeNodeType {
ll l,r,fa,fm,dis,mid;
};
struct TreeNodeType tree[maxn<<]; ll n,p,t,X; inline void in(ll &now)
{
char Cget=getchar();now=;
while(Cget>''||Cget<'') Cget=getchar();
while(Cget>=''&&Cget<='')
{
now=now*+Cget-'';
Cget=getchar();
}
} void tree_build(ll now,ll l,ll r)
{
tree[now].l=l,tree[now].r=r,tree[now].fm=;
if(l==r)
{
in(tree[now].dis);
tree[now].dis%=p;
return ;
}
tree[now].mid=l+r>>;
tree_build(now<<,l,tree[now].mid);
tree_build(now<<|,tree[now].mid+,r);
tree[now].dis=(tree[now<<].dis+tree[now<<|].dis)%p;
} inline void tree_down(ll now)
{
tree[now<<].dis=((tree[now<<].dis*tree[now].fm)%p+(tree[now<<].r-tree[now<<].l+)*tree[now].fa%p)%p;
tree[now<<|].dis=((tree[now<<|].dis*tree[now].fm)%p+(tree[now<<|].r-tree[now<<|].l+)*tree[now].fa%p)%p;
tree[now<<].fm=(tree[now<<].fm*tree[now].fm)%p;
tree[now<<|].fm=(tree[now<<|].fm*tree[now].fm)%p;
tree[now<<].fa=(tree[now<<].fa*tree[now].fm%p+tree[now].fa)%p;
tree[now<<|].fa=(tree[now<<|].fa*tree[now].fm%p+tree[now].fa)%p;
tree[now].fa=,tree[now].fm=;
} void tree_do(ll now,ll l,ll r)
{
if(tree[now].l==l&&tree[now].r==r)
{
if(t==)
{
tree[now].fm=(tree[now].fm*X)%p;
tree[now].fa=(tree[now].fa*X)%p;
tree[now].dis=(tree[now].dis*X)%p;
return ;
}
else if(t==)
{
tree[now].fa=(tree[now].fa+X)%p;
tree[now].dis=(tree[now].dis+(tree[now].r-tree[now].l+)*X)%p;
}
else X=(X+tree[now].dis)%p;
return ;
}
if(tree[now].fa||tree[now].fm!=) tree_down(now);
if(l>tree[now].mid) tree_do(now<<|,l,r);
else if(r<=tree[now].mid) tree_do(now<<,l,r);
else
{
tree_do(now<<,l,tree[now].mid);
tree_do(now<<|,tree[now].mid+,r);
}
tree[now].dis=(tree[now<<].dis+tree[now<<|].dis)%p;
} int main()
{
in(n),in(p);
tree_build(,,n);
ll m,u,v;
in(m);
while(m--)
{
in(t),in(u),in(v);
if(t==||t==) in(X),tree_do(,u,v);
else X=,tree_do(,u,v),printf("%lld\n",X);
}
return ;
}
AC日记——[Ahoi2009]Seq 维护序列seq bzoj 1798的更多相关文章
- BZOJ 1798: [Ahoi2009]Seq 维护序列seq( 线段树 )
线段树.. 打个 mul , add 的标记就好了.. 这个速度好像还挺快的...( 相比我其他代码 = = ) 好像是#35.. ---------------------------------- ...
- 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 老师交给小可可一个维护数列的任务,现在小可 ...
- 1798: [Ahoi2009]Seq 维护序列seq
1798: [Ahoi2009]Seq 维护序列seq Time Limit: 30 Sec Memory Limit: 64 MBSubmit: 2930 Solved: 1087[Submit ...
- BZOJ1798: [Ahoi2009]Seq 维护序列seq[线段树]
1798: [Ahoi2009]Seq 维护序列seq Time Limit: 30 Sec Memory Limit: 64 MBSubmit: 5504 Solved: 1937[Submit ...
- BZOJ1798: [Ahoi2009]Seq 维护序列seq
传送门 写这道题是为了get一个同时传送乘法下标和加法下标的小技巧,线段树模板题.不多说. 标记名字打错无限智力-- //BZOJ 1798 //by Cydiater //2016.9.13 #in ...
- 【BZOJ】1798: [Ahoi2009]Seq 维护序列seq(线段树)
http://www.lydsy.com/JudgeOnline/problem.php?id=1798 之前写了个快速乘..........................20多s...... 还好 ...
- bzoj 1798 [Ahoi2009]Seq 维护序列seq(线段树+传标)
[题目链接] http://www.lydsy.com/JudgeOnline/problem.php?id=1798 [题意] 给定一个序列,要求提供区间乘/加,以及区间求和的操作 [思路] 线段树 ...
随机推荐
- python3 练习题100例 (十三)
题目十三:将一个正整数分解质因数.例如:输入60,打印出60=2*2*3*5. #!/usr/bin/env python3 # -*- coding: utf-8 -*- ""& ...
- Why I get “No connection associated with this command”?
- day14之模块
一.列表生成式与生成表达式 1.列表生成式(数据量小) 要求:在列表内造100个元素 示例: l=[] for i in range(100): l.append('egg%s'%i) print(l ...
- Poj3061Subsequence
A sequence of N positive integers (10 < N < 100 000), each of them less than or equal 10000, a ...
- FreeMarker的<#if></#if>标签
<#if target??> xxxx </#if> 上面这段代码判断target??是否为null,如果不为null时才可以执行if里面的内容,为null时则不进到 if里面 ...
- [转]Git for windows 下vim解决中文乱码的有关问题
Git for windows 下vim解决中文乱码的问题 原文链接:Git for windows 下vim解决中文乱码的有关问题 1.右键打开Git bash: 2.cd ~ 3.vim .vim ...
- cf984e Elevator
ref我好菜啊 #include <iostream> #include <cstring> #include <cstdio> #include <cmat ...
- leetcode 【 Remove Element 】python 实现
题目: Given an array and a value, remove all instances of that value in place and return the new lengt ...
- ogre3D学习基础2 -- 顶点程序与片断程序
三.顶点程序与片断程序 顶点或者片断程序定义可以被多个材质使用,唯一的前提条件是必须在引用它之前在材质的渲染通路部分中定义. 一个低级顶点程序示例如下: vertex_program myVertex ...
- 微信小程序-----校园头条详细开发之列表展示数据
1.分类列表数据展示功能的实现 1.1 结构 1.2 代码实现 1.2.1 列表显示数据,.每次界面显示6条数据,发请求获取数据,动态存放 var app = getApp() Page({ dat ...