[Luogu3674]小清新人渣的本愿
题意
给你一个序列a,长度为n,有m次操作,每次询问一个区间是否可以选出两个数它们的差为x,或者询问一个区间是否可以选出两个数它们的和为x,或者询问一个区间是否可以选出两个数它们的乘积为x ,这三个操作分别为操作1,2,3
选出的这两个数可以是同一个位置的数
所有数据\(\le 10^5\)
sol
正好今天考试一道题要用到\(bitset\)就跑过来写一下。
所谓\(bitset\)其实就是一个不用手写的压位,一般用来优化暴力,复杂度\(O(\frac{n^2}{64})\)哈。(毕竟很多时候除个\(64\)复杂度就可以过了)
这个题哈。用莫队的方法离线处理每个询问,把每种数字出现的集合压进一个\(bitset\)。对于减法就直接用S
和S>>x
取交集判断是否为空。对于加法我们需要额外维护一个反过来的\(bitset\),然后也是右移一下然后取个交。
对于乘法,可以直接枚举因数判断是否存在即可。
复杂度\(O(\frac{n^2}{64}+n\sqrt n+m\sqrt n)\),所以说这是一个正确的复杂度。
莫队可以加一些优化,比如说对右端点排序的时候根据左端点所在块的奇偶性从大到小或者是从小到大排序。(还是快了蛮多的)
code
#include<cstdio>
#include<algorithm>
#include<cmath>
#include<bitset>
using namespace std;
int gi()
{
int x=0,w=1;char ch=getchar();
while ((ch<'0'||ch>'9')&&ch!='-') ch=getchar();
if (ch=='-') w=0,ch=getchar();
while (ch>='0'&&ch<='9') x=(x<<3)+(x<<1)+ch-'0',ch=getchar();
return w?x:-x;
}
const int N = 1e5;
int n,m,blk,a[N+5],cnt[N+5],ans[N+5];
struct query{
int opt,l,r,x,id;
bool operator < (const query &b) const
{
if (l/blk!=b.l/blk) return l/blk<b.l/blk;
return ((l/blk)&1)?r>b.r:r<b.r;
}
}q[N+5];
bitset<N+5>S1,S2;
void add(int x)
{
++cnt[x];
if (cnt[x]==1) S1[x]=1,S2[N-x]=1;
}
void del(int x)
{
--cnt[x];
if (cnt[x]==0) S1[x]=0,S2[N-x]=0;
}
int main()
{
n=gi();m=gi();blk=sqrt(n);
for (int i=1;i<=n;++i) a[i]=gi();
for (int i=1;i<=m;++i) q[i]=(query){gi(),gi(),gi(),gi(),i};
sort(q+1,q+m+1);
int L=1,R=0;
for (int i=1;i<=m;++i)
{
while (R<q[i].r) add(a[++R]);
while (L>q[i].l) add(a[--L]);
while (R>q[i].r) del(a[R--]);
while (L<q[i].l) del(a[L++]);
if (q[i].opt==1)
ans[q[i].id]=(S1&(S1>>q[i].x)).any();
if (q[i].opt==2)
ans[q[i].id]=(S1&(S2>>N-q[i].x)).any();
if (q[i].opt==3)
for (int j=1;j*j<=q[i].x;++j)
if (q[i].x%j==0)
if (S1[j]&&S1[q[i].x/j]) {ans[q[i].id]=1;break;}
}
for (int i=1;i<=m;++i) puts(ans[i]?"hana":"bi");
return 0;
}
[Luogu3674]小清新人渣的本愿的更多相关文章
- luogu3674 小清新人渣的本愿 (bitset+莫队)
对于加减,用bitset维护当前每个数有没有 对于乘,暴力枚举约数 然后莫队 复杂度$O(m(\sqrt{n}+\frac{c}{64}))$ #include<bits/stdc++.h> ...
- Luogu3674小清新人渣的本愿
https://zybuluo.com/ysner/note/1109536 题面 给你一个序列a,长度为n,有m次操作,每次询问一个区间 是否可以选出两个数它们的差为x 是否可以选出两个数它们的和为 ...
- LuoguP3674 小清新人渣的本愿 && BZOJ4810: [Ynoi2017]由乃的玉米田
题目地址 小清新人渣的本愿 [Ynoi2017]由乃的玉米田 所以这两题也就输出不一样而已 题解 这种lxl的题还是没修改操作的题基本就是莫队 分开考虑每个询问 1.减法 \(a-b=x⇒a=b+x\ ...
- P3674 小清新人渣的本愿
P3674 小清新人渣的本愿 一道妙不可言的题啊,,, 一看就知道是个莫队 考虑求答案 1号操作就是个大bitset,动态维护当前的bitset \(S\),把能取哪些值都搞出来,只要\(S\ and ...
- 【洛谷3674】小清新人渣的本愿(莫队,bitset)
[洛谷3674]小清新人渣的本愿(莫队,bitset) 题面 洛谷,自己去看去,太长了 题解 很显然的莫队. 但是怎么查询那几个询问. 对于询问乘积,显然可以暴力枚举因数(反正加起来也是\(O(n\s ...
- 洛谷 P3674 小清新人渣的本愿 [莫队 bitset]
传送门 题意: 给你一个序列a,长度为n,有Q次操作,每次询问一个区间是否可以选出两个数它们的差为x,或者询问一个区间是否可以选出两个数它们的和为x,或者询问一个区间是否可以选出两个数它们的乘积为x ...
- [Luogu 3674]小清新人渣的本愿
Description 题库链接 给你一个序列 \(A\) ,长度为 \(n\) ,有 \(m\) 次操作,每次询问一个区间是否可以 选出两个数它们的差为 \(x\) : 选出两个数它们的和为 \(x ...
- 【题解】Luogu P3674 小清新人渣的本愿
原题传送门 这题还算简单(我记得我刚学oi时就来写这题,然后暴力都爆零了) 看见无修改,那么这题应该是莫队 维护两个bitset,第二个是第一个的反串,bitset内维护每个数字是否出现过 第一种操作 ...
- 洛谷P3674 小清新人渣的本愿
题意:多次询问,区间内是否存在两个数,使得它们的和为x,差为x,积为x. n,m,V <= 100000 解: 毒瘤bitset...... 假如我们有询问区间的一个桶,那么我们就可以做到O(n ...
随机推荐
- Loadrunder脚本篇——Run-time Settings之Miscellaneous
作用说明 提供混杂设置,如错误处理,多线程,自动化事务设置等 注意:仅对指定协议有效 Error Handling Continue on Error 开启后,在VuGen中,如脚本中某个函数出错 ...
- Loadrunder之脚本篇——关联
关联的原理 关联也属于一钟特殊的参数化.一般参数化的参数来源于一个文件.一个定义的table.通过sql写的一个结果集等,但关联所获得的参数是服务器响应请求所返回的一个符合条件的.动态的值. 例子:常 ...
- VC 取消warning
#pragma warning (disable:4200) 4200是指具体哪个warning
- hadoop程序在本地模式调试作业
1.首先下载cygwin,例如安装在该目录下,D:\Program Files\cygwin\ 2.copy linux上的jar包到D:\Program Files\cygwin\home\lib ...
- 修改和重置WAMP的phpMyAdmin密码
WAMP是Windows下的Apache+Mysql/MariaDB+Perl/PHP/Python,常用来搭建动态网站或者服务器的开源软件. 1.下载页面:http://www.wampserver ...
- H3C 交换机设置telnet WEB用户
huwei : local-user admin password cipher @#$@#$ service-type telnet ssh service-type telnet ssh leve ...
- Linux下安装lrzsz上传下载工具
使用yum安装 为什么要使用yum安装? 答:安装十分方便,几乎不需要别的操作,只需要一个yum命令就可以完成所有的安装过程. yum -y install lrzsz 要有网络才行 输入命令:rz ...
- java.net.UnknownHostException异常处理
1.问题描述 最近迁移环境,在Linux系统下部署Java产品的应用,后台报出如下异常,系统报找不到名为“xxx-houtai1”的主机: 1 java.net.UnknownHostExceptio ...
- 直播P2P技术1-技术入门
1. 直播协议 直播协议主要有RTMP,HLS,MPEG-DASH,RTSP,HTTP-FLV等.每种协议都各有长短,比如RTMP延迟低,但诞生于Adobe,依赖于Flash Player,在如今FL ...
- EJS基本用法
1.引入 <script src="/src/ejs_production.js"></script> 2.模板 <script id="c ...