题目链接:http://www.lydsy.com/JudgeOnline/problem.php?id=4810


思路还是比较显然,第一反应应该就是莫队。

考虑怎么维护三个询问,想到了要维护每一个数字是否出现就想到了要用bitset。那么这道题就做完了。

莫队相当于是在利用bitset维护一个01序列$f$,表示每一个数字是否出现在这一段区间。

1.如果差为$x$,将这个$f$左移$x$然后判断是否和原来的$f$集合有交集即可。

2.如果和为$x$,将这个$f$翻转并左移$100000-x$然后判断是否和原来的$f$集合有交集即可。

3.如果积为$x$,直接${O(\sqrt{x})}$的枚举判断即可。

复杂度${O(n\sqrt{n}+\frac{n^{2}}{64})}$

 #include<iostream>
#include<algorithm>
#include<cstdio>
#include<cstdlib>
#include<cmath>
#include<cstring>
#include<queue>
#include<vector>
#include<map>
#include<bitset>
using namespace std;
#define llg int
#define maxn 100010
#define MA 100000
#define yyj(a) freopen(a".in","r",stdin),freopen(a".out","w",stdout); inline llg getint()
{
llg w=,q=; char c=getchar();
while((c<'' || c>'') && c!='-') c=getchar();
if (c=='-') q=, c=getchar(); while (c>='' && c<='') w=w*+c-'', c=getchar();
return q ? -w : w;
} bitset<MA+>f,g;
llg ans[maxn],n,m,a[maxn],KUAI,cnt[maxn]; struct node {llg ty,l,r,x,num;}ask[maxn]; bool cmp(const node&a,const node&b)
{
if (a.l/KUAI==b.l/KUAI) return a.r<b.r;
else return a.l/KUAI<b.l/KUAI;
} void init()
{
cin>>n>>m;
KUAI=sqrt(n);
for (llg i=;i<=n;i++) a[i]=getint();
for (llg i=;i<=m;i++)
ask[i].ty=getint(),ask[i].l=getint(),ask[i].r=getint(),ask[i].x=getint(),ask[i].num=i;
sort(ask+,ask+m+,cmp);
} int main()
{
yyj("mo");
init();
llg l=,r=;
for (llg i=;i<=m;i++)
{
while (l>ask[i].l) l--,cnt[a[l]]++,f[a[l]]=,g[MA-a[l]]=;
while (r<ask[i].r) r++,cnt[a[r]]++,f[a[r]]=,g[MA-a[r]]=;
while (l<ask[i].l) {cnt[a[l]]--; if (!cnt[a[l]]) f[a[l]]=,g[MA-a[l]]=; l++;}
while (r>ask[i].r) {cnt[a[r]]--; if (!cnt[a[r]]) f[a[r]]=,g[MA-a[r]]=; r--;} if (ask[i].ty==)
{
if (((f>>ask[i].x)&f).any()) ans[ask[i].num]=; else ans[ask[i].num]=; } if (ask[i].ty==)
{
if (((g>>(MA-ask[i].x))&f).any()) ans[ask[i].num]=; else ans[ask[i].num]=;
} if (ask[i].ty==)
{
for (llg k=;k*k<=ask[i].x;k++)
if (ask[i].x%k==)
{
if (f[k] && f[ask[i].x/k]) {ans[ask[i].num]=; break;}
}
}
if (ask[i].x== && f[]) ans[ask[i].num]=;
}
for (llg i=;i<=m;i++) puts(ans[i]?"yuno":"yumi");
return ;
}

【BZOJ】 4810: [Ynoi2017]由乃的玉米田的更多相关文章

  1. [BZOJ]4810: [Ynoi2017]由乃的玉米田

    Time Limit: 30 Sec  Memory Limit: 256 MB Description 由乃在自己的农田边散步,她突然发现田里的一排玉米非常的不美.这排玉米一共有N株,它们的高度参差 ...

  2. BZOJ 4810 [Ynoi2017]由乃的玉米田 (莫队 + bitset)

    题目链接  BZOJ 4810 首先对询问离线, 莫队算法处理. 首先我们可以用bitset维护处当前区间中是否存在某个数. 对于询问1, 我们可以用 ((f >> q[i].x) &am ...

  3. BZOJ 4810 [Ynoi2017]由乃的玉米田(莫队+bitset)

    [题目链接] http://www.lydsy.com/JudgeOnline/problem.php?id=4810 [题目大意] 给出一个数列,有三种区间查询, 分别查询区间是否存在两个数乘积为x ...

  4. BZOJ 4810 [Ynoi2017]由乃的玉米田 ——Bitset 莫队算法

    加法和减法的操作都能想到Bitset. 然后发现乘法比较难办,反正复杂度已经是$O(n\log{n})$了 枚举因数也不能更差了,直接枚举就好了. #include <map> #incl ...

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

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

  6. bzoj4810 [Ynoi2017]由乃的玉米田 bitset优化+暴力+莫队

    [Ynoi2017]由乃的玉米田 Time Limit: 30 Sec  Memory Limit: 256 MBSubmit: 917  Solved: 447[Submit][Status][Di ...

  7. 【BZOJ4810】[Ynoi2017]由乃的玉米田 bitset+莫队

    [BZOJ4810][Ynoi2017]由乃的玉米田 Description 由乃在自己的农田边散步,她突然发现田里的一排玉米非常的不美.这排玉米一共有N株,它们的高度参差不齐.由乃认为玉米田不美,所 ...

  8. bzoj 3594: [Scoi2014]方伯伯的玉米田 dp树状数组优化

    3594: [Scoi2014]方伯伯的玉米田 Time Limit: 60 Sec  Memory Limit: 128 MBSubmit: 314  Solved: 132[Submit][Sta ...

  9. bzoj4810 [Ynoi2017]由乃的玉米田

    Description 由乃在自己的农田边散步,她突然发现田里的一排玉米非常的不美.这排玉米一共有N株,它们的高度参差不齐. 由乃认为玉米田不美,所以她决定出个数据结构题   这个题是这样的: 给你一 ...

随机推荐

  1. python GIL :全局解释器

    cpython 解释器中存在一个GIL(全局解释器锁),无论多少个线程.多少颗cpu 他的作用就是保证同一时刻只有一个线程可以执行代码,因此造成了我们使用多线程的时候无法实现并行. 因为有GIL的存在 ...

  2. A - Shashlik Cooking CodeForces - 1040B

    http://codeforces.com/problemset/problem/1040/B Long story short, shashlik is Miroslav's favorite fo ...

  3. c->log技巧

    介绍: 在C代码里,有时会加入一些打印信息方便分析问题,可用如下代码替代打印函数,更加方便. // // Created by lady on 18-12-10. // #include <st ...

  4. sass基础学习(一)

    移动端布局各种问题 pc端布局各种问题sass 组件模块化面向对象编程ajax 框架学习 webpack 打包 性能优化 gulp是基于Nodejs的自动任务运行器她能自动化地完成 javascrip ...

  5. Django进阶之QuerySet和中介模型

    QuerySet QuerySet是查询集,就是传到服务器上的url里面的查询内容.其形态类似于Python的列表,列表中的元素是QuerySet对象.支持大部分列表的内置方法. 可切片 QueryS ...

  6. python框架之Flask(3)-Blueprint(蓝图)

    蓝图 用途 给开发者提供清晰的目录结构. 使用 目录结构 1.创建项目. 2.在项目目录下创建与项目名同名文件夹. 3.在 test_prj 文件夹下创建 __init__.py 文件,并在其中实例化 ...

  7. Struts2重要知识点总结

    一.interceptor拦截器的使用 第一种情况(指定action使用该拦截器):struts.xml文件的配置: <interceptors> <interceptor name ...

  8. phpstorm 破解版

    原链接https://blog.csdn.net/gu_wen_jie/article/details/79136475

  9. 记录在tiny6410平台上采用4GSD卡来启动uboot和烧写nand flash uboot

    下面这种方法是从网上转的 没有验证 环境:ubuntu 13.04一.首先制作sd启动盘: 插入SD卡    sudo dd iflag=dsync oflag=dsync if=tiny210v2- ...

  10. 基于ABP模块组件与依赖注入组件的项目插件开发

    注意,阅读本文,需要先阅读以下两篇文章,并且对依赖注入有一定的基础. 模块系统:http://www.cnblogs.com/mienreal/p/4537522.html 依赖注入:http://w ...