【线段树】【BZOJ1798】【AHOI2009】维护序列
还是那个学弟@lher出的丧题之一。
链接:http://www.lydsy.com/JudgeOnline/problem.php?id=1798
题意简析:就是题目啊。。。
解题思路:显然是线段树啊。。。根据乘法分配律处理一下区间乘法操作,其他就是简单的区间加法查询,很水吧owo。时间效率\(O(m \lg n) \)。
附AC代码:
- #include<stdio.h>
- #include<iostream>
- #include<cmath>
- #include<cstring>
- #include<string>
- #include<algorithm>
- #define ll long long
- #define mid ((l+r)>>1)
- #define ls (k<<1)
- #define rs (k<<1|1)
- using namespace std;
- struct zxy{
- ll val,mult,add;
- }tr[];
- int n,mod,q;
- inline int in(){
- int x=,f=;
- char ch=getchar();
- while(ch<''||ch>'') {if(ch=='-') f=-; ch=getchar();}
- while(ch>=''&&ch<='') x=x*+ch-'',ch=getchar();
- return x*f;
- }
- inline void pushdown(int k,int l,int r){
- if (tr[k].mult==&&!tr[k].add) return;
- int D=(r-l)+;
- tr[ls].add=(tr[ls].add*tr[k].mult+tr[k].add)%mod;
- tr[rs].add=(tr[rs].add*tr[k].mult+tr[k].add)%mod;
- tr[ls].mult=(tr[ls].mult*tr[k].mult)%mod;
- tr[rs].mult=(tr[rs].mult*tr[k].mult)%mod;
- tr[ls].val=(tr[ls].val*tr[k].mult+(D-(D>>))*tr[k].add)%mod;
- tr[rs].val=(tr[rs].val*tr[k].mult+(D>>)*tr[k].add)%mod;
- tr[k].mult=,tr[k].add=;
- }
- inline void combine(int k){
- tr[k].val=(tr[ls].val+tr[rs].val)%mod;
- }
- inline void update(int k,int l,int r,int a,int b,int mult,int add){
- if (l>=a&&r<=b){
- tr[k].mult=tr[k].mult*mult%mod;
- tr[k].add=(tr[k].add*mult+add)%mod;
- tr[k].val=(tr[k].val*mult+(r-l+)*add)%mod;
- return;
- }
- pushdown(k,l,r);
- if (a<=mid) update(ls,l,mid,a,b,mult,add);
- if (b>mid) update(rs,mid+,r,a,b,mult,add);
- combine(k);
- }
- inline ll query(int k,int l,int r,int a,int b){
- if (l==a&&r==b) return tr[k].val%mod;
- pushdown(k,l,r);
- if (b<=mid) return query(ls,l,mid,a,b);
- if (a>mid) return query(rs,mid+,r,a,b);
- return (query(ls,l,mid,a,mid)+query(rs,mid+,r,mid+,b))%mod;
- }
- inline void built(int k,int l,int r){
- tr[k].mult=; tr[k].add=;
- if(l==r) {
- tr[k].val=in();
- return;
- }
- built(ls,l,mid);built(rs,mid+,r);
- combine(k);
- }
- int main(){
- n=in(),mod=in(); built(,,n);
- q=in();
- for (register int i=; i<=q; ++i){
- int typ=in(),l=in(),r=in();
- if (typ==) update(,,n,l,r,,in());
- if (typ==) update(,,n,l,r,in(),);
- if (typ==)printf("%lld\n",query(,,n,l,r));
- }
- return ;
- }
本文由Melacau编写,Melacau代表M星向您问好,如果您不是在我的博客http://www.cnblogs.com/Melacau上看到本文,请您向我联系,email:13960948839@163.com.
【线段树】【BZOJ1798】【AHOI2009】维护序列的更多相关文章
- BZOJ1798[Ahoi2009]维护序列——线段树
题目描述 老师交给小可可一个维护数列的任务,现在小可可希望你来帮他完成. 有长为N的数列,不妨设为a1,a2,…,aN .有如下三种操作形式: (1)把数列中的一段数全部乘一个值; (2 ...
- bzoj1798 [Ahoi2009]维护序列
Description 老师交给小可可一个维护数列的任务,现在小可可希望你来帮他完成. 有长为N的数列,不妨设为a1,a2,…,aN .有如下三种操作形式: (1)把数列中的一段数全部乘一个值; (2 ...
- 【线段树】Bzoj1798 [AHOI2009] 维护序列
Description 老师交给小可可一个维护数列的任务,现在小可可希望你来帮他完成. 有长为N的数列,不妨设为a1,a2,…,aN .有如下三种操作形式: (1)把数列中的一段数全部乘一个值; (2 ...
- BZOJ_1798_[AHOI2009]维护序列_线段树
BZOJ_1798_[AHOI2009]维护序列_线段树 题意:老师交给小可可一个维护数列的任务,现在小可可希望你来帮他完成. 有长为N的数列,不妨设为a1,a2,…,aN .有如下三种操作形式: ( ...
- 洛谷P3373 【模板】线段树 2 && P2023 [AHOI2009]维护序列——题解
题目传送: P3373 [模板]线段树 2 P2023 [AHOI2009]维护序列 该题较传统线段树模板相比多了一个区间乘的操作.一提到线段树的区间维护问题,就自然想到了“懒标记”:为了降低时间复 ...
- P2023 [AHOI2009]维护序列 题解(线段树)
题目链接 P2023 [AHOI2009]维护序列 解题思路 线段树板子.不难,但是...有坑.坑有多深?一页\(WA\). 由于乘法可能乘\(k=0\),我这种做法可能会使结果产生负数.于是就有了这 ...
- 洛谷P2023 [AHOI2009]维护序列(线段树区间更新,区间查询)
洛谷P2023 [AHOI2009]维护序列 区间修改 当我们要修改一个区间时,要保证 \(ax+b\) 的形式,即先乘后加的形式.当将区间乘以一个数 \(k\) 时,原来的区间和为 \(ax+b\) ...
- [Luogu 2023] AHOI2009 维护序列
[Luogu 2023] AHOI2009 维护序列 恕我冒昧这和线段树模板二有个琴梨区别? #include <cstdio> int n,m; long long p; class S ...
- 洛谷 2023 [AHOI2009]维护序列
洛谷 2023 [AHOI2009]维护序列 洛谷原题传送门 这个题也是一道经典的线段树模版(其实洛谷的模版二改一下输入顺序就能AC),其中包括区间乘法修改.区间加法修改.区间查询三个操作. 线段树的 ...
- 洛谷 P2023 [AHOI2009]维护序列 题解
P2023 [AHOI2009]维护序列 题目描述 老师交给小可可一个维护数列的任务,现在小可可希望你来帮他完成. 有长为N的数列,不妨设为a1,a2,-,aN .有如下三种操作形式: (1)把数列中 ...
随机推荐
- Bate版敏捷冲刺报告--day0
1 团队介绍 团队组成: PM:齐爽爽(258) 小组成员:马帅(248),何健(267),蔡凯峰(285) Git链接:https://github.com/WHUSE2017/C-team 2 ...
- 1013团队Beta冲刺day2
项目进展 李明皇 今天解决的进度 优化了信息详情页的布局:日期显示,添加举报按钮等 优化了程序的数据传递逻辑 明天安排 程序运行逻辑的完善 林翔 今天解决的进度 实现微信端消息发布的插入数据库 明天安 ...
- 冲刺NO.5
Alpha冲刺第五天 站立式会议 项目进展 今日项目完成内容主要包括了JS的学习,事务管理员模块与学生模块的完善与补充,并且开始编写信用信息管理模块和奖惩事务管理模块. 问题困难 前端部分的技术掌握的 ...
- python 进程复习
import os import time ret = os.fork() # 创建子线程 if ret ==0: # 子进程中返回值为0,父进程>0 while True: print('.. ...
- JAVA线程池原理详解(1)
线程池的优点 1.线程是稀缺资源,使用线程池可以减少创建和销毁线程的次数,每个工作线程都可以重复使用. 2.可以根据系统的承受能力,调整线程池中工作线程的数量,防止因为消耗过多内存导致服务器崩溃. 线 ...
- egg.js 的优缺点
egg.js 的优缺点 优点 所有的 web开发的点都考虑到了 agent 很有特色 文件夹规划到位 扩展能力优秀 缺点 最大的问题在于: 使用 loader 加载之后,失去了代码提示的能力 监控和运 ...
- New UWP Community Toolkit - DeveloperTools
概述 UWP Community Toolkit 中有一个开发者工具集 DeveloperTools,可以帮助开发者在开发过程中进行 UI 和功能的调试,本篇我们结合代码详细讲解 Develope ...
- redis 持久化之 RDB
redis的运维过程中,我们对数据持久化做一个基本的总结. 1什么是持久化: redis 所有数据保持在内存中,对数据的更新将异步地保存到磁盘上. RDB 文件创建的过程是直接从内存 写入到我们我磁盘 ...
- .net core页面使用layui的HtmlHelper扩展
Vino.Core.Extensions.Layui 如果您的.net core 2.0项目使用layui来渲染表单,那么您可以尝试使用这个扩展库可以帮你减少代码和工作量. 项目地址:https:// ...
- codeforces 798c Mike And Gcd Problem
题意: 给出一个数列,现在有一种操作,可以任何一个a[i],用a[i] – a[i+1]和a[i]+a[i+1]替代a[i]和a[i+1]. 问现在需要最少多少次操作,使得整个数列的gcd大于1. 思 ...