bzoj4105: [Thu Summer Camp 2015]平方运算
填坑
我不知道怎么算的,但是所有环的LCM数不会超过60
然后用线段树维护这个东西,每个节点记录子树内的循环节
没到循环节的暴力枚举
复杂度是nlogn再乘以循环节长度
#include<cstdio>
#include<iostream>
#include<cstring>
#include<cstdlib>
#include<algorithm>
#include<cmath>
#include<vector> #define lc (now<<1)
#define rc (now<<1|1)
#define mid (ql+qr)/2
using namespace std;
typedef long long LL;
const int _=1e2;
const int maxn=1e5+_;
const int maxp=1e4+_;
const int maxh=+;
const int mbit=(<<)+_;
int gcd(int a,int b){if(a==)return b;return gcd(b%a,a);}
int lcm(int a,int b){return a/gcd(a,b)*b;} int nxt[maxp];bool inh[maxp];int tim,v[maxp];
void init(int p)
{
for(int i=;i<p;i++)nxt[i]=i*i%p;
tim=;
for(int i=;i<p;i++)
if(v[i]==)
{
v[i]=++tim;
for(int k=nxt[i];;k=nxt[k])
{
if(v[k]==tim)
{
inh[k]=true;
for(int u=nxt[k];u!=k;u=nxt[u])inh[u]=true;
break;
}
if(v[k]>)break;
v[k]=tim;
}
}
} //--------------------------------------yu--------------------------------------------------- struct hh
{
int len,pos,h[maxh];
hh(){}
int insert(int d)
{
if(inh[d])
{
len=;pos=;h[++len]=d;
for(int k=nxt[d];k!=d;k=nxt[k])h[++len]=k;
return ;
}
return -;
}
void merge(hh h1,hh h2)
{
len=lcm(h1.len,h2.len);pos=;
for(int k=,i=h1.pos,j=h2.pos;k<=len;k++,i=i%h1.len+,j=j%h2.len+)
h[k]=h1.h[i]+h2.h[j];
}
int ad(int b){pos=(pos+b-)%len+;return h[pos];}
};
struct trnode{int sum,la;hh h;};int w[maxn];
struct Segtree
{
trnode tr[*mbit];
Segtree(){}
void update(int now)
{
tr[now].sum=tr[lc].sum+tr[rc].sum;
if(tr[lc].la!=-&&tr[rc].la!=-)
{
tr[now].la=;
tr[now].h.merge(tr[lc].h,tr[rc].h);
}
else tr[now].la=-;
}
void pushdown(int now)
{
if(tr[now].la<=)return ;
tr[lc].sum=tr[lc].h.ad(tr[now].la),tr[lc].la=(tr[lc].la+tr[now].la-)%tr[lc].h.len+;
tr[rc].sum=tr[rc].h.ad(tr[now].la),tr[rc].la=(tr[rc].la+tr[now].la-)%tr[rc].h.len+;
tr[now].la=;
}
void bt(int now,int ql,int qr)
{
if(ql==qr){tr[now].sum=w[ql],tr[now].la=tr[now].h.insert(w[ql]);return ;}
bt(lc,ql,mid),bt(rc,mid+,qr),update(now);
}
void change(int now,int ql,int qr,int l,int r)
{
if(ql==l&&qr==r&&tr[now].la!=-){tr[now].sum=tr[now].h.ad();tr[now].la++;return ;}
if(ql==qr){tr[now].la=tr[now].h.insert(nxt[tr[now].sum]),tr[now].sum=nxt[tr[now].sum];return ;}
pushdown(now);
if(r<=mid) change(lc,ql,mid,l,r);
else if(mid+<=l)change(rc,mid+,qr,l,r);
else change(lc,ql,mid,l,mid),change(rc,mid+,qr,mid+,r);
update(now);
}
int getsum(int now,int ql,int qr,int l,int r)
{
if(ql==l&&qr==r)return tr[now].sum;
pushdown(now);
if(r<=mid) return getsum(lc,ql,mid,l,r);
else if(mid+<=l)return getsum(rc,mid+,qr,l,r);
else return getsum(lc,ql,mid,l,mid)+getsum(rc,mid+,qr,mid+,r);
}
}S; //---------------------------------data structure--------------------------------------------- int main()
{
freopen("a.in","r",stdin);
freopen("a.out","w",stdout);
int n,Q,p;
scanf("%d%d%d",&n,&Q,&p);
init(p); for(int i=;i<=n;i++)scanf("%d",&w[i]);
S.bt(,,n); int op,x,y;
while(Q--)
{
scanf("%d%d%d",&op,&x,&y);
if(op==)S.change(,,n,x,y);
else printf("%d\n",S.getsum(,,n,x,y));
} return ;
}
bzoj4105: [Thu Summer Camp 2015]平方运算的更多相关文章
- BZOJ4105 [Thu Summer Camp 2015]平方运算 【线段树】
题目链接 BZOJ4105 题解 平方操作orz,虽说应该是线段树,但是不会维护啊QAQ 小瞧一眼题解... 平方成环?环长\(lcm\)小于\(60\)? 果然还是打表找规律题.... 那就很好做了 ...
- 2018.10.18 bzoj4105: [Thu Summer Camp 2015]平方运算(线段树)
传送门 线段树妙题. 显然平方几次就会循环(打表证明不解释). 然后所有环长度的lcmlcmlcm不大于70. 因此维护一下当前区间中的节点是否全部在环上. 不是直接暴力到叶子节点修改. 否则整体打标 ...
- bzoj:4105: [Thu Summer Camp 2015]平方运算
Description Input 第一行有三个整数N,M,p,分别代表序列的长度.平方操作与询问操作的总次数以及在平方操作中所要模的数. 接下来一行N个数代表一开始的序列{X1,X2,... ...
- 4105: [Thu Summer Camp 2015]平方运算
首先嘛这道题目只要知道一个东西就很容易了:所有循环的最小公约数<=60,成一条链的长度最大为11,那么我们就可以用一个很裸的方法.对于在链上的数,我们修改直接暴力找出并修改.对于在环上的数,我们 ...
- [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 ...
- bzoj 4104 [Thu Summer Camp 2015]解密运算——思路
题目:https://www.lydsy.com/JudgeOnline/problem.php?id=4104 想了很久,想出一个 nlogn (也许是 n2logn )的,可惜空间是 n2 . 已 ...
随机推荐
- LA 4973异面线段
题目大意:给两条线段求他们间的最小距离的平方(以分数形式输出). 贴个模版吧!太抽象了. #include<cstdio> #include<cmath> #include&l ...
- git fetch tag 获取远程tag
获取远程的tag( 远程存在,本地不存在) git fetch origin tag 2.4.7 出现如下文字,说明获取远程tag成功 remote: Counting objects: 2, don ...
- WEB学习-CSS盒模型
盒子的区域 一个盒子中主要的属性就5个:width.height.padding.border.margin. width是“宽度”的意思,CSS中width指的是内容的宽度,而不是盒子的宽度. he ...
- 2017 ACM/ICPC Asia Regional Urumuqi Online 记录
比赛题目链接 Urumuqi
- 【WEB基础】HTML & CSS 基础入门(5)边框与背景
前面(HTML图片) 漂亮的网页肯定少不了边框与背景的修饰,本篇笔记就是说明如何为网页上的元素设置边框或者背景(背景颜色和背景图片). 之前,先了解一下HTML中的图片元素,因为图片标签的使用非常简单 ...
- Spring中Bean的定义继承
以下内容引用自http://wiki.jikexueyuan.com/project/spring/bean-definition-inheritance.html: Bean定义继承 bean定义可 ...
- 【原】理解javascript中的闭包(***********************************************)
阅读目录 什么是闭包? 闭包的特性 闭包的作用: 闭包的代码示例 注意事项 总结 闭包在javascript来说是比较重要的概念,平时工作中也是用的比较多的一项技术.下来对其进行一个小小的总结 回到顶 ...
- 关于ios异步加载图片的几个开源项目
一.HjCache 原文:http://www.markj.net/hjcache-iphone-image-cache/ 获取 HJCache: HJCache is up on github h ...
- 在Ubuntu 10.10下安装JDK配置Eclipse及Tomcat
1.安装JDK 1.1.到官网下载相关的JDK 这里下载的是 jdk-6u23-linux-i586.bin. 下载地址:http://www.oracle.com/technetwork/java/ ...
- 【Todo】Java8新特性学习
参考这篇文章吧: http://blog.csdn.net/vchen_hao/article/details/53301073 还有一个系列