【BZOJ】 4810: [Ynoi2017]由乃的玉米田
题目链接: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]由乃的玉米田的更多相关文章
- [BZOJ]4810: [Ynoi2017]由乃的玉米田
Time Limit: 30 Sec Memory Limit: 256 MB Description 由乃在自己的农田边散步,她突然发现田里的一排玉米非常的不美.这排玉米一共有N株,它们的高度参差 ...
- BZOJ 4810 [Ynoi2017]由乃的玉米田 (莫队 + bitset)
题目链接 BZOJ 4810 首先对询问离线, 莫队算法处理. 首先我们可以用bitset维护处当前区间中是否存在某个数. 对于询问1, 我们可以用 ((f >> q[i].x) &am ...
- BZOJ 4810 [Ynoi2017]由乃的玉米田(莫队+bitset)
[题目链接] http://www.lydsy.com/JudgeOnline/problem.php?id=4810 [题目大意] 给出一个数列,有三种区间查询, 分别查询区间是否存在两个数乘积为x ...
- BZOJ 4810 [Ynoi2017]由乃的玉米田 ——Bitset 莫队算法
加法和减法的操作都能想到Bitset. 然后发现乘法比较难办,反正复杂度已经是$O(n\log{n})$了 枚举因数也不能更差了,直接枚举就好了. #include <map> #incl ...
- LuoguP3674 小清新人渣的本愿 && BZOJ4810: [Ynoi2017]由乃的玉米田
题目地址 小清新人渣的本愿 [Ynoi2017]由乃的玉米田 所以这两题也就输出不一样而已 题解 这种lxl的题还是没修改操作的题基本就是莫队 分开考虑每个询问 1.减法 \(a-b=x⇒a=b+x\ ...
- bzoj4810 [Ynoi2017]由乃的玉米田 bitset优化+暴力+莫队
[Ynoi2017]由乃的玉米田 Time Limit: 30 Sec Memory Limit: 256 MBSubmit: 917 Solved: 447[Submit][Status][Di ...
- 【BZOJ4810】[Ynoi2017]由乃的玉米田 bitset+莫队
[BZOJ4810][Ynoi2017]由乃的玉米田 Description 由乃在自己的农田边散步,她突然发现田里的一排玉米非常的不美.这排玉米一共有N株,它们的高度参差不齐.由乃认为玉米田不美,所 ...
- bzoj 3594: [Scoi2014]方伯伯的玉米田 dp树状数组优化
3594: [Scoi2014]方伯伯的玉米田 Time Limit: 60 Sec Memory Limit: 128 MBSubmit: 314 Solved: 132[Submit][Sta ...
- bzoj4810 [Ynoi2017]由乃的玉米田
Description 由乃在自己的农田边散步,她突然发现田里的一排玉米非常的不美.这排玉米一共有N株,它们的高度参差不齐. 由乃认为玉米田不美,所以她决定出个数据结构题 这个题是这样的: 给你一 ...
随机推荐
- httpClient实例--返回响应部分并且转换成对象
import java.io.ByteArrayOutputStream;import java.io.IOException;import java.io.InputStream;import ja ...
- 用ASPOSE.Cells将HTML表格存为Excel
前端生成的html表格经常需要导出到excel中,利用JS和Office控件可以做到,但仅限于IE,还要启用安全设置. 想找一个简单的办法将HTML内容直接转换成Excel文件,如果直接修改网页头信息 ...
- lower_bound && upper_bound
用lower_bound进行二分查找 ●在从小到大排好序的基本类型数组上进行二分查找. 这是二分查找的一种版本,试图在已排序的[first,last)中寻找元素value.如果[first,last ...
- [bash][awk] bash下使用awk方便的列求和
这么多年,始终在用awk进行文本处理.但是一直没有好好的学习awk的语法.所以很多情况都是知其然,不知其所以然. 如今,亦如此.先记下来如下,以后有时间系统的学习一下awk的语法. ┬─[tong@T ...
- Emmet.vim 教程
Emmet.vim 教程 May 5, 2012 目录 1 下载 Emmet.vim 2 安装 Emmet.vim 3 使用 Emmet.vim 4 余话 Emmet 项目原先叫 Zen Coding ...
- C++——创建类的时候用new与不用new 的区别(转)
C++在创建对象的时候可以采用两种方式:(例如类名为Test) Test test 或者 Test* pTest = new Test(). 这两种方法都可以实例化一个对象,但是这两种 ...
- 解决docker镜像pull超时问题
第一步:通过dig @114.114.114.114 registry-1.docker.io找到可用IP dig @114.114.114.114 registry-1.docker.io 第二步: ...
- 接口测试工具-Jmeter使用笔记(七:用户定义的变量)
使用场景:一组API根据业务流程制作成测试脚本,想要移植到其他测试环境时,由于数据库发生了变更,有些初始化数据也相应发生了变化,例如环境地址.请求路径等等.博主甚至把服务器地址和接口的部分共同请求路径 ...
- what's the 跳空
出自 MBA智库百科(https://wiki.mbalib.com/) 什么是跳空 跳空在日语中叫“窗口”,英语是“gap”,又称为即价格跳空,是指汇率在快速波动时产生的曲线的最低价与曲线的最高价之 ...
- Redis入门到高可用(十四)—— bitmap
一.初步认识 二.API 1.setbit 2.getbit 3.bitcount 4.bitop 5.bitpos 三.位图使用 四. 使用经验