[bzoj4722]由乃
身为10班人,就凭标题,这道题是一定要做的。
但是做了才发现有毒。。。。所以是信念和题解和大腿支撑了我!
先“假设”自己实力过硬,推出了结论:当区间过大时,必定存在一种方案可以输出”Yuno“。剩下就是这区区几个数的乱搞了。
数据结构学傻先不动声色地敲了一个线段树维护所有的立方操作,并且我发现自从noip2015挂过lazy tag以后就再也不会写错了。。。。这就是传说中教训的力量
然后我还是请教了一些更优秀的维护方法,不过万变不离其宗,这个常数说不要就不要了吧。。。。
接下来,我开始想当然:差不多了。。。再敲个快速幂。。。随便搞下。。。差不多了。。。
后来幸好看了下V,不是质数,那又要求phi啊?!
而且不一定互质,不仅要求phi而且要提取质因数啊?!
不想写啊,只能向倍增势力低头。
再后来,思考“区区几个数的乱搞”,好像并不容易。看了题解说得很含蓄,发现是个乱搞的思想。
对于区间【L,R】,以mid为界,左边枚举两个不相交子集,右边枚举两个不相交子集,判断它们的合法性。
于是就T了,原来我的复杂度和常数达到了十分可怕的境地。这就很不爽了。因为我不会卡常。
再回过头来看那个“假设”,有实力的人证一证,没实力的人写个暴力找下规律,发现可以把题解中的下界13改为10,这样就卡过去了。
(当然,你写9也能A)。。。。数据太随机了。
事情还没结束,time排名垫底了,原来是我乱搞写错了。四重循环,不挂才怪。正确做法还得写一个桶,把左边所有值扔进桶里,这样询问就飞起来了。
最后shy说:你这样也能过,说明常数实在太小了。
2333
改了一下。。。仍旧快垫底?
#include<cstdio>
#include<cstring>
#include<algorithm>
#define N 200020
#define ll long long
],tree[N*];ll fa[N][];
],V[];
ll a[N],b[N];
void push_down(int p,int st,int ed){
){
f[p+p]+=f[p];f[p+p+]+=f[p];;
tree[p+p]+=f[p]*(mid-st+);tree[p+p+]+=f[p]*(ed-mid);
f[p]=;
}
}
void update(int L,int R,int st,int ed,int p){
;;
)push_down(p,st,ed);
if(R<=mid)update(L,R,st,mid,p+p);else
,ed,p+p+);else
update(L,mid,st,mid,p+p),update(mid+,R,mid+,ed,p+p+);
}
int query(int x,int st,int ed,int p){
if(st==x&&ed==x)return tree[p];
)push_down(p,st,ed);
;
if(x<=mid)return query(x,st,mid,p+p);else
,ed,p+p+);
}
ll quickmi(ll x,ll k){
ll tmp=,a=x;
){
==){tmp=tmp*a%mo;}
a=a*a%mo;k=k/;
}return tmp;
}
void work(int st,int ed,int cc){
;
<<(mid-st+))-,l2=(<<(ed-mid))-;
;u<=l1;u++)
;v<=l1-u;v++))||v!=){
,a2=,a3=,a4=;
for(int i=st;i<=mid;i++){
<<(i-st);
)a1+=b[i]+;)a2+=b[i]+;
}
if(a1>a2)std::swap(a1,a2);
;return;}
V[a2-a1]=;tot++;bb[tot]=a2-a1;
}
;x<=l2;x++)
;y<=l2-x;y++))||y!=){
,a2=,a3=,a4=;
;i<=ed;i++){
<<(i-mid-);
)a3+=b[i]+;)a4+=b[i]+;
}
if(a3>a4)std::swap(a3,a4);
;return;}
){fool=;return;}
}
}
int main()
{
//freopen("yono.in","r",stdin);//freopen("my.out","w",stdout);
scanf("%d%d%d",&n,&m,&mo);
;i<=n;i++)scanf("%lld",&a[i]);
;i<mo;i++) fa[i][]=i*i%mo*i%mo;
;j<=;j++)
;i<mo;i++)
fa[i][j]=fa[fa[i][j-]][j-];
;cc<=m;cc++){
int op,L,R;scanf("%d%d%d",&op,&L,&R);
){update(L,R,,n,);continue;}
>)printf("Yuno\n");else{
for(int i=L;i<=R;i++){
ll tt=query(i,,n,),x=tt,tmp=,now=a[i];
b[i]=a[i];
;j>=;j--)<<j)){
x-=<<j;b[i]=fa[b[i]][j]%mo;
}
}
fool=;tot=;
work(L,R,cc);
;i<=tot;i++)V[bb[i]]=;
)printf("Yuno\n");else printf("Yuki\n");
}
}
}
bzoj4722
[bzoj4722]由乃的更多相关文章
- 【BZOJ4722】由乃
[BZOJ4722]由乃 题面 bzoj 题解 考虑到区间长度为\(14\)时子集个数\(2^{14}>14\times 1000\),由抽屉原理,区间长度最多为\(13\)(长度大于这个值就一 ...
- [BZOJ4722]由乃[鸽巢原理+bitset+倍增]
题意 给定长为 \(n\) 序列 \(a\) ,要求支持两种操作: \(1.\) 询问在一个区间 \([l,r]\) 中,是否能够选出两个交集为空的集合 $ \rm X ,Y$, 使得 \(\sum_ ...
- [Bzoj4722]由乃(线段树好题)(倍增处理模数小快速幂)
4722: 由乃 Time Limit: 20 Sec Memory Limit: 512 MBSubmit: 360 Solved: 131[Submit][Status][Discuss] D ...
- $bzoj4722$ 由乃 搜索
正解:搜索 解题报告: 传送门$QwQ$ 首先发现长度为$len$的子集的值域为$[0,v\cdot len+len]$,数量为$2^{len}$.所以当$2^{len}\geq v\cdot len ...
随机推荐
- Postgresql 简单配置 (ubuntu server 14.04.3)
安装和配置 ubuntu server 已经自动安装了progresql,故安装步骤就省略 初始postgresql没有密码,不能使用,需要先设置密码,命令(从网上随意找的)如下: sudo su p ...
- jq绑定事件的4种方式
jQuery提供了多种绑定事件的方式,每种方式各有其特点,明白了它们之间的异同点,有助于我们在写代码的时候进行正确的选择,从而写出优雅而容易维护的代码.下面我们来看下jQuery中绑定事件的方式都有哪 ...
- Quick Cocos 旋转子弹的实现中我学到的
self 在lua中相当于java中的this lua中的任何变量在没有赋值前, 都可以看做是nil lua变量有3种,成员变量: self.变量名 = 局部变量: local 变量名 = 全局变量 ...
- hdu 4481 Time travel(高斯求期望)(转)
(转)http://blog.csdn.net/u013081425/article/details/39240021 http://acm.hdu.edu.cn/showproblem.php?pi ...
- MySQL 磁盘I/O问题
一.使用磁盘阵列:RAID,廉价磁盘冗余阵列,可靠性,性能好. 二.使用 Symbolic Links 分布I/O 利用操作系统的符号链接将不同的数据库或表.索引指向不同的物理磁盘,达到分布磁盘I/O ...
- Ecmascript 6新特性
声明变量由var变成let.let实际上为JavaScript新增了块级作用域.let与var相比具有的特性有 1.不允许重复声明一个变量 var a=5; var a=7; let b=6; let ...
- BZOJ2134——单选错位
1.题意:这就是说考试的时候抄串了一位能对几个(雾) 2.分析:这是一个期望问题,期望就是平均,E(a+b)=E(a)+E(b),所以我们直接算出每个点能对几个就好,那么就是1/max(a[i],a[ ...
- EFUpdate
using System; using System.Collections.Generic; using System.Configuration; using System.Data; using ...
- 《转载》GET,POST,PUT,DELETE的区别
本文转载自:转载请说明出处,谢谢[hyddd(http://www.cnblogs.com/hyddd/)] Http定义了与服务器交互的不同方法,最基本的方法有4种,分别是GET,POST,PUT, ...
- 2016ACM青岛区域赛题解
A.Relic Discovery_hdu5982 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/65536 K (Jav ...