首先想到线段树,然后刚开始写忽然想到树状数组求和岂不是更快,而且编程复杂度又小,于是把之前写的删掉,写树状数组,写完模版之后忽然发现这题竟然是区间修改!

于是又删掉重写,忽然发现不会处理又加又乘的,果断看题解……

经过几乎两个小时的调试,终于1A。

需要注意的是,一定要让线段树的每一个区间保存的值时刻为正确的,这样才能在调用时直接返回。比如说这道题的change和query操作的最后一句话:

sum:=f(g[k<<1]+g[k<<1+1])

而不是

sum:=f(t[k<<1].sum+t[k<<1+1].sum)

时刻记住这点就ok了。一开始我还以为我的模版记错了呢……

代码:

 type node=record
l,r,ti,ad,sum:int64;
end;
var i,n,m,tagtime,tagadd,ch,x,y,c,p:longint;
t:array[..] of node;
function f(x:int64):int64;
begin
f:=x mod p;
end;
function g(k:longint):longint;
begin
with t[k] do
begin
g:=f(f(sum*ti)+f(ad*(r-l+)));
end;
end;
procedure build(x,y,k:longint);
var mid:longint;
begin
with t[k] do
begin
l:=x;r:=y;ad:=;ti:=;
if l=r then begin read(sum);sum:=f(sum);exit;end;
mid:=(l+r)>>;
build(l,mid,k<<);
build(mid+,r,k<<+);
sum:=f(t[k<<].sum+t[k<<+].sum);
end;
end;
procedure pushdown(k:longint);
begin
with t[k] do
begin
if ti<> then
begin
sum:=f(sum*ti);
t[k<<].ti:=f(t[k<<].ti*ti);
t[k<<].ad:=f(t[k<<].ad*ti);
t[k<<+].ti:=f(t[k<<+].ti*ti);
t[k<<+].ad:=f(t[k<<+].ad*ti);
ti:=;
end;
if ad<> then
begin
sum:=f(sum+ad*(r-l+));
t[k<<].ad:=f(t[k<<].ad+ad);
t[k<<+].ad:=f(t[k<<+].ad+ad);
ad:=;
end;
end;
end;
procedure change(x,y,k:longint);
var mid:longint;
begin
with t[k] do
begin
if (l=x) and (r=y) then
begin
ti:=(ti*tagtime) mod p;
ad:=(ad*tagtime+tagadd) mod p;
exit;
end;
pushdown(k);
mid:=(l+r)>>;
if y<=mid then change(x,y,k<<)
else if x>mid then change(x,y,k<<+)
else
begin
change(x,mid,k<<);
change(mid+,y,k<<+);
end;
sum:=f(g(k<<)+g(k<<+));
end;
end;
function query(x,y,k:longint):longint;
var mid:longint;
begin
with t[k] do
begin
pushdown(k);
if (l=x) and (r=y) then exit(f(sum));
mid:=(l+r)>>;
if y<=mid then query:=f(query(x,y,k<<))
else if x>mid then query:=f(query(x,y,k<<+))
else query:=f(f(query(x,mid,k<<))+f(query(mid+,y,k<<+)));
sum:=f(g(k<<)+g(k<<+));
end;
end;
procedure init;
begin
readln(n,p);
build(,n,);
end;
procedure main;
begin
readln(m);
for i:= to m do
begin
read(ch);
if ch= then
begin
readln(x,y,tagtime);
tagadd:=;
change(x,y,);
end
else if ch= then
begin
readln(x,y,tagadd);
tagtime:=;
change(x,y,);
end
else
begin
readln(x,y);
writeln(query(x,y,));
end;
end;
end;
begin
init;
main;
end.

虽然现在已经12:30了,但我感觉,很开心。做了这道题,值!

bzoj1789 AHOI 维护数列(线段树)的更多相关文章

  1. [AHOI2009]维护序列 (线段树)

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

  2. [P2023][AHOI2009]维护序列(线段树)

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

  3. BZOJ1798[Ahoi2009]维护序列——线段树

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

  4. 【AHOI2009】 维护序列 - 线段树

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

  5. Codeforces 446C - DZY Loves Fibonacci Numbers(斐波那契数列+线段树)

    Codeforces 题目传送门 & 洛谷题目传送门 你可能会疑惑我为什么要写 *2400 的题的题解 首先一个很明显的想法是,看到斐波那契数列和 \(10^9+9\) 就想到通项公式,\(F ...

  6. BZOJ.5286.[AHOI/HNOI2018]转盘(线段树)

    BZOJ LOJ 洛谷 如果从\(1\)开始,把每个时间\(t_i\)减去\(i\),答案取决于\(\max\{t_i-i\}\).记取得最大值的位置是\(p\),答案是\(t_p+1+n-1-p=\ ...

  7. BZOJ 1798 AHOI2009 Seq 维护序列 线段树

    题目大意:维护一个序列,提供三种操作: 1.将区间中每个点的权值乘上一个数 2.将区间中每个点的权值加上一个数 3.求一段区间的和对p取模的值 2631的超^n级弱化版.写2631之前能够拿这个练练手 ...

  8. P3703 [SDOI2017]树点涂色 LCT维护颜色+线段树维护dfs序+倍增LCA

    \(\color{#0066ff}{ 题目描述 }\) Bob有一棵\(n\)个点的有根树,其中1号点是根节点.Bob在每个点上涂了颜色,并且每个点上的颜色不同. 定义一条路径的权值是:这条路径上的点 ...

  9. P1438 无聊的数列 (线段树)

    题目链接 Solution 直接维护一个差分的线段树就好了. 其中线段树的节点代表 \(r\) 比 \(l\) 多多少. Code #include<bits/stdc++.h> #def ...

随机推荐

  1. php入门变量之变量的间接引用、连接字符串和连接赋值运算符

    [1]变量的间接引用: <?php $a = 'b'; $$a = '123'; echo $b; ?> 上面的输出结果是123 我们可以看到在第二行代码中多了一个$,并通过指定的名称访问 ...

  2. K最近邻算法

    K最近邻(K-Nearest-Neighbour,KNN)算法是机器学习里简单易掌握的一个算法.通过你的邻居判断你的类型,“近朱者赤,近墨者黑”表达了K近邻的算法思想. 一.算法描述: 1.1 KNN ...

  3. python的浅拷贝和深拷贝

    python对象有两种拷贝的形式:浅拷贝和深拷贝. 在<python核心编程>中看到对这两种拷贝的分析,觉得十分收益,所以记录在此. id()方法:id()方法可以查看某个对象的ID,类似 ...

  4. 第一章 基本的SQL语句 (SQL基础)

    1. 查询数据库系统时间,常以服务器默认的格式进行显示(根据数据库的字符集而定): 注意:dual 为数据库中的虚表,隶属于管理员 sys 用户,但所有的用户都可以访问:无实际意义,仅充当select ...

  5. 【socket】一分钟理清 socket udpsocket tcpsocket tcplistener TCPClient和 UDPClient

    socket 套接字接口是各种语言tcp udp的网络操作的基础. 直接用socket 对象开发 可以选择 udpsocket  或者 tcpsocket ,两者在使用上仅一些方法和参数不同,所有的底 ...

  6. MVC5+EF6+BootStrap3.3.5 博客系统之项目搭建(一)

    环境:vs2013,sql2008R2 引用版本:MVC5,EF6,BootStrap3.3.5 在之前一直都是webfrom开发,虽然开发简单:但是有很多不足的地方.在之前开发都是webfrom+M ...

  7. 在PyCharm里配置SubVersion

    1.如果PyCharm不支持svn ,那么下载svn命令行安装包,下载地址:http://sourceforge.net/projects/win32svn/ 例如:安装到 D:\software\s ...

  8. Ext4.2 grid 条件查询使用

    项目中用到Ext4.2,初次接触,用的不是太熟,做个总结,恳请指正! 1.grid重新设置条件,查询结果不是从第1页开始 在处理grid条件查询时,点击搜索按钮调用store.load()方法时,会把 ...

  9. 远程登陆MS azure Linux 虚拟机

    http://blogs.technet.com/b/uktechnet/archive/2013/11/12/running-a-remote-desktop-on-a-windows-azure- ...

  10. Linux中的MyEclipse配置Hadoop

    一.所需软件 注意:安装MyEclipse后,我再已安装软件里找不到MyEclipse,所以我在root权限下用命令行启动MyEclipse,貌似避免了很多权限问题. sudo su 输入密码 cd ...