luogu

题意

给你一个序列a,长度为n,有m次操作,每次询问一个区间是否可以选出两个数它们的差为x,或者询问一个区间是否可以选出两个数它们的和为x,或者询问一个区间是否可以选出两个数它们的乘积为x ,这三个操作分别为操作1,2,3

选出的这两个数可以是同一个位置的数

所有数据\(\le 10^5\)

sol

正好今天考试一道题要用到\(bitset\)就跑过来写一下。

所谓\(bitset\)其实就是一个不用手写的压位,一般用来优化暴力,复杂度\(O(\frac{n^2}{64})\)哈。(毕竟很多时候除个\(64\)复杂度就可以过了)

这个题哈。用莫队的方法离线处理每个询问,把每种数字出现的集合压进一个\(bitset\)。对于减法就直接用SS>>x取交集判断是否为空。对于加法我们需要额外维护一个反过来的\(bitset\),然后也是右移一下然后取个交。

对于乘法,可以直接枚举因数判断是否存在即可。

复杂度\(O(\frac{n^2}{64}+n\sqrt n+m\sqrt n)\),所以说这是一个正确的复杂度。

莫队可以加一些优化,比如说对右端点排序的时候根据左端点所在块的奇偶性从大到小或者是从小到大排序。(还是快了蛮多的)

code

  1. #include<cstdio>
  2. #include<algorithm>
  3. #include<cmath>
  4. #include<bitset>
  5. using namespace std;
  6. int gi()
  7. {
  8. int x=0,w=1;char ch=getchar();
  9. while ((ch<'0'||ch>'9')&&ch!='-') ch=getchar();
  10. if (ch=='-') w=0,ch=getchar();
  11. while (ch>='0'&&ch<='9') x=(x<<3)+(x<<1)+ch-'0',ch=getchar();
  12. return w?x:-x;
  13. }
  14. const int N = 1e5;
  15. int n,m,blk,a[N+5],cnt[N+5],ans[N+5];
  16. struct query{
  17. int opt,l,r,x,id;
  18. bool operator < (const query &b) const
  19. {
  20. if (l/blk!=b.l/blk) return l/blk<b.l/blk;
  21. return ((l/blk)&1)?r>b.r:r<b.r;
  22. }
  23. }q[N+5];
  24. bitset<N+5>S1,S2;
  25. void add(int x)
  26. {
  27. ++cnt[x];
  28. if (cnt[x]==1) S1[x]=1,S2[N-x]=1;
  29. }
  30. void del(int x)
  31. {
  32. --cnt[x];
  33. if (cnt[x]==0) S1[x]=0,S2[N-x]=0;
  34. }
  35. int main()
  36. {
  37. n=gi();m=gi();blk=sqrt(n);
  38. for (int i=1;i<=n;++i) a[i]=gi();
  39. for (int i=1;i<=m;++i) q[i]=(query){gi(),gi(),gi(),gi(),i};
  40. sort(q+1,q+m+1);
  41. int L=1,R=0;
  42. for (int i=1;i<=m;++i)
  43. {
  44. while (R<q[i].r) add(a[++R]);
  45. while (L>q[i].l) add(a[--L]);
  46. while (R>q[i].r) del(a[R--]);
  47. while (L<q[i].l) del(a[L++]);
  48. if (q[i].opt==1)
  49. ans[q[i].id]=(S1&(S1>>q[i].x)).any();
  50. if (q[i].opt==2)
  51. ans[q[i].id]=(S1&(S2>>N-q[i].x)).any();
  52. if (q[i].opt==3)
  53. for (int j=1;j*j<=q[i].x;++j)
  54. if (q[i].x%j==0)
  55. if (S1[j]&&S1[q[i].x/j]) {ans[q[i].id]=1;break;}
  56. }
  57. for (int i=1;i<=m;++i) puts(ans[i]?"hana":"bi");
  58. return 0;
  59. }

[Luogu3674]小清新人渣的本愿的更多相关文章

  1. luogu3674 小清新人渣的本愿 (bitset+莫队)

    对于加减,用bitset维护当前每个数有没有 对于乘,暴力枚举约数 然后莫队 复杂度$O(m(\sqrt{n}+\frac{c}{64}))$ #include<bits/stdc++.h> ...

  2. Luogu3674小清新人渣的本愿

    https://zybuluo.com/ysner/note/1109536 题面 给你一个序列a,长度为n,有m次操作,每次询问一个区间 是否可以选出两个数它们的差为x 是否可以选出两个数它们的和为 ...

  3. LuoguP3674 小清新人渣的本愿 && BZOJ4810: [Ynoi2017]由乃的玉米田

    题目地址 小清新人渣的本愿 [Ynoi2017]由乃的玉米田 所以这两题也就输出不一样而已 题解 这种lxl的题还是没修改操作的题基本就是莫队 分开考虑每个询问 1.减法 \(a-b=x⇒a=b+x\ ...

  4. P3674 小清新人渣的本愿

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

  5. 【洛谷3674】小清新人渣的本愿(莫队,bitset)

    [洛谷3674]小清新人渣的本愿(莫队,bitset) 题面 洛谷,自己去看去,太长了 题解 很显然的莫队. 但是怎么查询那几个询问. 对于询问乘积,显然可以暴力枚举因数(反正加起来也是\(O(n\s ...

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

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

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

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

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

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

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

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

随机推荐

  1. 流量分析系统--zookeeper集群部署

    安装zookeeper mkdir apps tar -zxvf zookeeper-3.4.5.tar.gz -C apps [root@mini1 zookeeper-3.4.5]# rm -rf ...

  2. 函数没有返回值,默认返回undefined

    var  a =( function(){return})(); a = undefined;

  3. CodeForces - 691E Xor-sequences 【矩阵快速幂】

    题目链接 http://codeforces.com/problemset/problem/691/E 题意 给出一个长度为n的序列,从其中选择k个数 组成长度为k的序列,因为(k 有可能 > ...

  4. Kattis - sortofsorting 【排序】

    题意 给出一系列字符串,然后要排序 排序规则 只按前两位按字典序来排序,如果前两位完全一样,则按输入的顺序来排 思路 要用 冒泡排序 不能用STL里面的 SORT 因为它不稳定 AC代码 #inclu ...

  5. PAT 天梯赛 L1-031. 到底是不是太胖了 【水】

    题目链接 https://www.patest.cn/contests/gplt/L1-031 AC代码 #include <iostream> #include <cstdio&g ...

  6. 提高开发效率 -> 图片

    相比于文字, 我们从图片中获取的信息是更快和更多的. 所以, 应当大量使用图片, 大量地截图和看图, 不管是针对资料还是代码都应如此. 这里给大家推荐两个好用的小工具, 一个是截图(DuckLink ...

  7. VSCode隐藏node_modules目录

    使用VSCode,打开一个工程时,发现node_modules目录包含到工程中了,问题: settings.json配置如下,可以自己定制忽略的文件夹: search.exclude 用来忽略搜索的文 ...

  8. Struts2笔记01——基础MVC架构(转)

    原始内容:https://www.tutorialspoint.com/struts_2/basic_mvc_architecture.htm Apache Struts 2是用来创建企业级Java ...

  9. https网站无法加载http路径的js和css

    在https的网站中引用http路径的js或css会导致不起作用,其形如: <script src="http://code.jquery.com/jquery-1.11.0.min. ...

  10. 考勤助手——基于CS三层结构的子系统设计

    因为小组比较倾向于cs分层结构的风格,所以基于对考勤助手最初的体系架构的设计进行了子系统的分层设计,如下图: 1.教务老师安排课程子系统 2.教务老师查询相关信息的子系统 3.任课教师管理考勤子系统 ...