2018.10.18 bzoj4105: [Thu Summer Camp 2015]平方运算(线段树)
传送门
线段树妙题。
显然平方几次就会循环(打表证明不解释)。
然后所有环长度的lcmlcmlcm不大于70.
因此维护一下当前区间中的节点是否全部在环上。
不是直接暴力到叶子节点修改。
否则整体打标记。
简单合并一下就行了。(细节见代码)
代码:
#include<bits/stdc++.h>
#define N 100005
#define lc (p<<1)
#define rc (p<<1|1)
#define mid (T[p].l+T[p].r>>1)
using namespace std;
inline int read(){
int ans=0;
char ch=getchar();
while(!isdigit(ch))ch=getchar();
while(isdigit(ch))ans=(ans<<3)+(ans<<1)+(ch^48),ch=getchar();
return ans;
}
int n,m,mod,a[N],tot=0,tim[N],cnt=0,nxt[10005];
bool inloop[10005],vis[10005];
struct Node{int l,r,sum,cir[70],pos,tag,len;bool in;}T[N<<2];
inline void solve(int p,int val){
if(!(T[p].in=inloop[T[p].sum=val]))return;
T[p].len=1,T[p].cir[T[p].pos=0]=val;
for(int i=nxt[val];i!=val;i=nxt[i])T[p].cir[T[p].len++]=i;
}
inline int lcm(int a,int b){return a/__gcd(a,b)*b;}
inline void pushup(int p){
T[p].sum=T[lc].sum+T[rc].sum;
T[p].in=T[lc].in&T[rc].in;
if(!T[p].in)return;
T[p].len=lcm(T[lc].len,T[rc].len);
int tl=T[lc].pos,tr=T[rc].pos;
for(int i=0;i<T[p].len;++i){
T[p].cir[i]=T[lc].cir[tl++]+T[rc].cir[tr++];
if(tl==T[lc].len)tl=0;
if(tr==T[rc].len)tr=0;
}
T[p].pos=0;
}
inline void pushnow(int p,int v){
T[p].tag+=v,T[p].pos+=v;
if(T[p].pos>=T[p].len)T[p].pos%=T[p].len;
T[p].sum=T[p].cir[T[p].pos];
}
inline void pushdown(int p){if(T[p].tag)pushnow(lc,T[p].tag),pushnow(rc,T[p].tag),T[p].tag=0;}
inline void build(int p,int l,int r){
T[p].l=l,T[p].r=r;
if(l==r)return solve(p,a[l]);
build(lc,l,mid),build(rc,mid+1,r),pushup(p);
}
inline void update(int p,int ql,int qr){
if(ql<=T[p].l&&T[p].r<=qr&&T[p].in)return pushnow(p,1);
if(T[p].l==T[p].r)return solve(p,nxt[T[p].sum]);
pushdown(p);
if(qr<=mid)update(lc,ql,qr);
else if(ql>mid)update(rc,ql,qr);
else update(lc,ql,mid),update(rc,mid+1,qr);
pushup(p);
}
inline int query(int p,int ql,int qr){
if(ql<=T[p].l&&T[p].r<=qr)return T[p].sum;
pushdown(p);
if(qr<=mid)return query(lc,ql,qr);
if(ql>mid)return query(rc,ql,qr);
return query(lc,ql,mid)+query(rc,mid+1,qr);
}
int main(){
n=read(),m=read(),mod=read();
for(int i=1;i<=n;++i)a[i]=read();
for(int i=0;i<mod;++i)nxt[i]=i*i%mod,inloop[i]=true;
for(int i=0;i<mod;++i)
if(!vis[i]){
int tmp=i;
while(!vis[tmp])vis[tmp]=1,tmp=nxt[tmp];
for(int j=i;j!=tmp;j=nxt[j])inloop[j]=false;
}
build(1,1,n);
while(m--){
int op=read(),l=read(),r=read();
if(!op)update(1,l,r);
else printf("%d\n",query(1,l,r));
}
return 0;
}
2018.10.18 bzoj4105: [Thu Summer Camp 2015]平方运算(线段树)的更多相关文章
- BZOJ4105 [Thu Summer Camp 2015]平方运算 【线段树】
题目链接 BZOJ4105 题解 平方操作orz,虽说应该是线段树,但是不会维护啊QAQ 小瞧一眼题解... 平方成环?环长\(lcm\)小于\(60\)? 果然还是打表找规律题.... 那就很好做了 ...
- bzoj4105: [Thu Summer Camp 2015]平方运算
填坑 我不知道怎么算的,但是所有环的LCM数不会超过60 然后用线段树维护这个东西,每个节点记录子树内的循环节 没到循环节的暴力枚举 复杂度是nlogn再乘以循环节长度 #include<cst ...
- bzoj:4105: [Thu Summer Camp 2015]平方运算
Description Input 第一行有三个整数N,M,p,分别代表序列的长度.平方操作与询问操作的总次数以及在平方操作中所要模的数. 接下来一行N个数代表一开始的序列{X1,X2,... ...
- 4105: [Thu Summer Camp 2015]平方运算
首先嘛这道题目只要知道一个东西就很容易了:所有循环的最小公约数<=60,成一条链的长度最大为11,那么我们就可以用一个很裸的方法.对于在链上的数,我们修改直接暴力找出并修改.对于在环上的数,我们 ...
- 2018.10.18 NOIP训练 ZUA球困难综合征(线段树)
传送门 考虑到模数等于7 * 13 * 17 * 19. 那么只需要维护四棵线段树求出每个数处理之后模7,13,17,197,13,17,197,13,17,19的值再用crtcrtcrt合并就行了. ...
- [Thu Summer Camp 2015]解密运算
4104: [Thu Summer Camp 2015]解密运算 Time Limit: 10 Sec Memory Limit: 512 MB Description 对于一个长度为N的字符串,我 ...
- 【BZOJ 4104】 4104: [Thu Summer Camp 2015]解密运算 (智商)
4104: [Thu Summer Camp 2015]解密运算 Time Limit: 10 Sec Memory Limit: 512 MBSubmit: 370 Solved: 237 De ...
- BZOJ4104:[Thu Summer Camp 2015]解密运算——题解
https://www.lydsy.com/JudgeOnline/problem.php?id=4104 对于一个长度为N的字符串,我们在字符串的末尾添加一个特殊的字符".".之 ...
- BZOJ4104 [Thu Summer Camp 2015]解密运算 【乱搞】
题目链接 BZOJ4104 题解 我们将已知字符排序,由循环就可以得到一个对应关系 如样例就是: 0->第5行 1->第1行 1->第2行 1->第3行 1->第5行 2 ...
随机推荐
- leetcode976
public class Solution { public int LargestPerimeter(int[] A) { var list = A.OrderByDescending(x => ...
- leetcode977
public class Solution { public int[] SortedSquares(int[] A) { return A.Select(x => x * x).ToList( ...
- SQL 2012 分页取数据
,), data int ) select * from t1 row rows only create clustered index t1c on t1(id) declare @i int ) ...
- Java 阿里云 邮件(带附件)发送
简单的使用. 阿里云每天免费200封 1000封才2块钱..465端口 使用正常25 端口 不正常 package com.gwzx.framework.utils; import java.util ...
- Gradle Maven部署,转化
参考:(易百教程)http://www.yiibai.com/gradle/gradle_deployment.html 目录: Gradle部署 Maven转化为Gradle Gradle部署: c ...
- String类的intern()方法
0.引言 什么都先不说,先看下面这个引入的例子: String str1 = new String("SEU")+ new String("Calvin"); ...
- OPTION SQL_SELECT_LIMIT=DEFAULT'
You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version ...
- Java Magic. Part 2: 0xCAFEBABE
Java Magic. Part 2: 0xCAFEBABE @(Base)[JDK, magic, 黑魔法] 转载请写明:原文地址 英文原文 系列文章: -Java Magic. Part 1: j ...
- git cherry-pick基本使用
git cherry-pick可以选择某一分支中的一个或几个commit来进行操作--commit 使用场景: 稳定版本分支1与开发版本分支2,不能直接把两个分支合并,否则会导致版本混乱,要将分支2中 ...
- substring_index 用法
substring_index http://blog.csdn.net/wolinxuebin/article/details/7845917 1.substring_index(str,delim ...