身为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]由乃的更多相关文章

  1. 【BZOJ4722】由乃

    [BZOJ4722]由乃 题面 bzoj 题解 考虑到区间长度为\(14\)时子集个数\(2^{14}>14\times 1000\),由抽屉原理,区间长度最多为\(13\)(长度大于这个值就一 ...

  2. [BZOJ4722]由乃[鸽巢原理+bitset+倍增]

    题意 给定长为 \(n\) 序列 \(a\) ,要求支持两种操作: \(1.\) 询问在一个区间 \([l,r]\) 中,是否能够选出两个交集为空的集合 $ \rm X ,Y$, 使得 \(\sum_ ...

  3. [Bzoj4722]由乃(线段树好题)(倍增处理模数小快速幂)

    4722: 由乃 Time Limit: 20 Sec  Memory Limit: 512 MBSubmit: 360  Solved: 131[Submit][Status][Discuss] D ...

  4. $bzoj4722$ 由乃 搜索

    正解:搜索 解题报告: 传送门$QwQ$ 首先发现长度为$len$的子集的值域为$[0,v\cdot len+len]$,数量为$2^{len}$.所以当$2^{len}\geq v\cdot len ...

随机推荐

  1. Alpha阶段项目总结

    1.我们的软件要解决什么问题?是否定义得很清楚?是否对典型用户和典型场景有清晰的描述? 我们的软件是一款面向高校学生的简单快速的云笔记,不仅具有笔记的添加.修改.查看和删除功能,还有笔记公开功能,用户 ...

  2. react+redux官方实例TODO从最简单的入门(1)-- 前言

    刚进公司的时候,一点react不会,有一个需求要改,重构页面!!!完全懵逼,一点不知道怎么办!然后就去官方文档,花了一周时间,就纯react实现了页面重构,总体来说,react还是比较简单的,由于当初 ...

  3. git diff 生成patch, git apply patch 打补丁方法说明,以及分支管理的简单操作。

    git diff 简易操作说明 先git log 查看commit ID, 记录你想要打的补丁的ID 比如说: git log commit 4ff35d800fa62123a28b7bda2a04e ...

  4. Activity系列讲解---数据传递

    在Android中,不同的Activity实例可能运行在一个进程中,也可能运行在不同的进程中.因此需要一种特别的机制帮助我们在Activity之间传递消息.Android中通过Intent对象来表示一 ...

  5. 【EasyUI】 日期格式化

    本文经过了测试,解决getFullyear() is not a function等问题 效果如下: 首先: Oracle中字段设置为DATE,MySQL中设置为DATETIME,MyBatis中会自 ...

  6. [MySQL]MySQL之权限管理

    一.MySQL权限简介 关于mysql的权限简单的理解就是mysql允许你做你全力以内的事情,不可以越界.比如只允许你执行select操作,那么你就不能执行update操作.只允许你从某台机器上连接m ...

  7. ACM/ICPC 之 DP解有规律的最短路问题(POJ3377)

    //POJ3377 //DP解法-解有规律的最短路问题 //Time:1157Ms Memory:12440K #include<iostream> #include<cstring ...

  8. 浅析Java中的final关键字(转载)

    自http://www.cnblogs.com/dolphin0520/p/3736238.html转载 一.final关键字的基本用法 在Java中,final关键字可以用来修饰类.方法和变量(包括 ...

  9. select初始化添加option,通过标签给出回显值,由于回显值和初始化值option中有一个值重复,去重等问题!

    第一张图片: 第二张图片 /** *该方法是为了去重,所谓去重就是 因为回显给select附上了值并设置为selected选中状态,而在我们初始化所有的select添加option元素中于回显的值重复 ...

  10. tp框架实现验证码

    今天来看一个小插件. tp框架是怎么实现验证码的. 又到了我们千篇一律的时候了,首先呢,先做一个用来显示的html界面名为:zhuce.html <!DOCTYPE html PUBLIC &q ...