这题是莫队维护bitset。

然而我并不会bitset以前讲过认为不考就没学

我真的太菜了。

首先维护一个权值的bitset——s。

操作3比较简单,我们可以\(\sqrt{x}\)枚举约数然后判断就行了。

操作1就是求是否存在

\[\exists{a,b},a-b=x
\]

移一下项

\[a=x+b
\]

也就是\(\text{(s<<x)}\)&\(x\neq0\)。

那么操作2该怎么办?

我们先设\(b'=n-b\)因为\(x=a+b\)

\[a-b'=a-(n-b)=a+b-n=x-n
\]

然后类比操作1就行了。

#include<iostream>
#include<cstring>
#include<cstdio>
#include<cmath>
#include<algorithm>
#include<bitset>
using namespace std;
const int N=100101;
int n,m,a[N],block[N],cnt[N];
string ans[N];
struct ques{
int l,r,type,id,x;
}qu[N];
bool cmp(ques a,ques b){
if(block[a.l]==block[b.l])return a.r<b.r;
else return block[a.l]<block[b.l];
}
bitset<N> x,y;
int read(){
int sum=0,f=1;char ch=getchar();
while(ch<'0'||ch>'9'){if(ch=='-')f=-1;ch=getchar();}
while(ch>='0'&&ch<='9'){sum=sum*10+ch-'0';ch=getchar();}
return sum*f;
}
int main(){
n=read();m=read();
int Block=sqrt(n);
for(int i=1;i<=n;i++)a[i]=read(),block[i]=(i-1)/Block+1;
for(int i=1;i<=m;i++)qu[i].type=read(),qu[i].l=read(),qu[i].r=read(),qu[i].x=read(),qu[i].id=i;
sort(qu+1,qu+1+m,cmp);
int l=1,r=0;
for(int i=1;i<=m;i++){
while(r<qu[i].r){
r++;
cnt[a[r]]++;
if(cnt[a[r]]==1)x[a[r]]=1,y[n-a[r]]=1;
}
while(l>qu[i].l){
l--;
cnt[a[l]]++;
if(cnt[a[l]]==1)x[a[l]]=1,y[n-a[l]]=1;
}
while(r>qu[i].r){
if(cnt[a[r]]==1)x[a[r]]=0,y[n-a[r]]=0;
cnt[a[r]]--;
r--;
}
while(l<qu[i].l){
if(cnt[a[l]]==1)x[a[l]]=0,y[n-a[l]]=0;
cnt[a[l]]--;
l++;
}
if(qu[i].type==1){
if((x&(x<<qu[i].x)).any())ans[qu[i].id]="hana";
else ans[qu[i].id]="bi";
}
else if(qu[i].type==2){
if(qu[i].x-n>=0){
if(((y<<(qu[i].x-n))&x).any())ans[qu[i].id]="hana";
else ans[qu[i].id]="bi";
}
else{
if(((x<<(n-qu[i].x))&y).any())ans[qu[i].id]="hana";
else ans[qu[i].id]="bi";
}
}
else{
for(int j=1;j<=sqrt(qu[i].x);j++)
if(qu[i].x%j==0&&x[j]&&x[qu[i].x/j])ans[qu[i].id]="hana";
if(ans[qu[i].id]!="hana")ans[qu[i].id]="bi";
}
}
for(int i=1;i<=m;i++)cout<<ans[i]<<endl;
return 0;
}

luogu P3674 小清新人渣的本愿(莫队+bitset)的更多相关文章

  1. P3674 小清新人渣的本愿 莫队+bitset

    ennmm...bitset能过系列. 莫队+bitset \(\mathcal{O}(m\sqrt n + \frac{nm}{w})\) 维护一个正向的 bitset <N> mem ...

  2. 洛谷 P3674 小清新人渣的本愿 [莫队 bitset]

    传送门 题意: 给你一个序列a,长度为n,有Q次操作,每次询问一个区间是否可以选出两个数它们的差为x,或者询问一个区间是否可以选出两个数它们的和为x,或者询问一个区间是否可以选出两个数它们的乘积为x ...

  3. 【题解】Luogu P3674 小清新人渣的本愿

    原题传送门 这题还算简单(我记得我刚学oi时就来写这题,然后暴力都爆零了) 看见无修改,那么这题应该是莫队 维护两个bitset,第二个是第一个的反串,bitset内维护每个数字是否出现过 第一种操作 ...

  4. luogu P3674 小清新人渣的本愿

    传送门 毒瘤lxl 本质是莫队,关键是怎么处理询问 这里需要开两个bitset(记为\(b1,b2\)),分别存\(x\)和\(n-x\)是否出现 对于询问1,即\(x-y=z\),由于\(y=x-z ...

  5. P3674 小清新人渣的本愿

    P3674 小清新人渣的本愿 一道妙不可言的题啊,,, 一看就知道是个莫队 考虑求答案 1号操作就是个大bitset,动态维护当前的bitset \(S\),把能取哪些值都搞出来,只要\(S\ and ...

  6. 洛谷P3674 小清新人渣的本愿(莫队)

    传送门 由乃tql…… 然后抄了一波zcy大佬的题解 我们考虑把询问给离线,用莫队做 然后用bitset维护,每一位代表每一个数字是否存在,记为$now1$ 然后再记录一个$now1$的反串$now2 ...

  7. 洛谷P3674 小清新人渣的本愿

    题意:多次询问,区间内是否存在两个数,使得它们的和为x,差为x,积为x. n,m,V <= 100000 解: 毒瘤bitset...... 假如我们有询问区间的一个桶,那么我们就可以做到O(n ...

  8. 洛谷 P3674 小清新人渣的本愿

    想看题目的戳我. 我刚开始觉得这道题目好难. 直到我从Awson大佬那儿了解到有一个叫做bitset的STL,这道题目就很容易被解开了. 想知道这个神奇的bitset的戳我. 这个题目一看就感觉是莫队 ...

  9. [Luogu 3674]小清新人渣的本愿

    Description 题库链接 给你一个序列 \(A\) ,长度为 \(n\) ,有 \(m\) 次操作,每次询问一个区间是否可以 选出两个数它们的差为 \(x\) : 选出两个数它们的和为 \(x ...

随机推荐

  1. 路飞学城Python-Day32

    36-进程池线程池 开多线程实现并发的效率是高的,当用户没有那么多的时候,服务器是可以承受压力的 但是一定要以某种方式来设置并发数,让服务器能够实现稳定的运行,控制服务器的线程数 设置池,往里面放池的 ...

  2. MySQL 关闭 binlog 日志

    [关闭binlog日志] 1.vim /etc/my.cnf 注释如下内容: #log-bin=mysql-bin #binlog_format=mixed #server-id = 1 #expir ...

  3. Laravel 多条件搜索查询

    做查询功能时,输入的关键词有的为空,有的有值,如何实现多功能查询呢?这里介绍一种方法.(基于laravel) 原理很简单,第一步:判断接收的值,第二步:写查询语句.具体实现如下: //首先,创建句柄: ...

  4. pip常见用法汇总

    1.pip安装 yum -y install epel-release && yum -y install python-pip 2.pip安装软件 (1)安装单个软件:pip ins ...

  5. spring mvc 下载

    1.代码: response.setContentType("application/msword;charset=GBK"); try { response.setHeader( ...

  6. HDU 2841

    明显,当(X,Y)=1时,是可以看见的. 这题,记得POJ 上也有类似的一题... 不过比较奇怪的是,我以为会超时,因为范围达到了100000,但竟然直接枚举没超时.... #include < ...

  7. 关于amd64和ia64的理解

    关于amd64和ia64的理解 学习了:http://blog.csdn.net/zubin006/article/details/5060383 IA64指的是Intel安腾系列CPU,不是X86架 ...

  8. 16、sockect

    一.局域网因特网 服务器是指提供信息的计算机或程序,客户机是指请求信息的计算机或程序,而网络用于连接服务器与客户机,实现两者之间的通信.但有时在某个网络中很难将服务器和客户机区分开.我们通常说的“局域 ...

  9. node-webkit 主页面和 iframe 页通讯

    <html lang="en-US"> <head> <title>Hello World!</title> <style&g ...

  10. 闭包(closure)与协程共用时要注意的事情

    闭包是一种能够让你用非常舒服的方式来编程的小技巧,Go也支持闭包. 假设从来没有接触过闭包,想在一開始就弄懂什么是闭包(closure)是非常困难的,就像递归一样,直到你真正写过.用过它,你才干真正的 ...