【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株,它们的高度参差不齐. 由乃认为玉米田不美,所以她决定出个数据结构题 这个题是这样的: 给你一 ...
随机推荐
- java.sql.SQLException: Field 'id' doesn't have a default value(用eclipse操作数据库时报了这种奇怪的错误)的原因与解决方法
1.错误原因 由于id在数据库表中是作为主键,但是在插入的过程中,没有给予数值,并且没有让其自增 2.解决办法 修改数据库表中的id,让其自增(在插入的过程中,不插入id数据时)
- mysql limit 性能问题分析
问题重现 // todo 参考文章: MySQL 单表分页 Limit 性能优化 Scalable MySQL: Avoid offset for large tables 证明为什么用limit时, ...
- MySQL数据库(增删查改)
创建一个表:create table user( uid varchar(10) , pwd int(10) ); 学生表: create table student( sno varchar(20) ...
- python语法_变量及命名规则
变量:存储信息的,日后被调用,修改操作 常量:固定不变的量,字母大写 变量命名规则: 1 有字母,数字以及下划线等符号组成 2 区分大小写 3 不能使用数字开头,不能含有特殊字符和空格 4 不能使用 ...
- Android开发入门经典【申明:来源于网络】
Android开发入门经典[申明:来源于网络] 地址:http://wenku.baidu.com/view/6e7634050740be1e650e9a7b.html?re=view
- [Day9]面向对象
1.面向过程与面向对象 (1)面向对象思维方式是一种更符合人们思考习惯的思想 (2)面向过程思维方式中更多的体现的是执行者,而面向对象中更多的体现的是指挥者 (3)面向对象思维方式将复杂的问题简单化 ...
- Python_tkinter(1)_窗口创建与布局
环境:Python 3.7.2 1. 窗口基本创建(窗口标题.窗口大小) import tkinter from tkinter import * # 初始化Tk() root = Tk() # 设置 ...
- MySQL5.7 虚拟列实现表达式或函数索引
MySQL5.7 虚拟列实现表达式或函数索引 http://www.linuxidc.com/Linux/2015-11/125162.htm https://dev.mysql.com/doc/re ...
- ORA-00444: background process DBRM failed while starting
SQL> startup 报错:ORA-00444: background process DBRM failed while startingORA-00020:maximum number ...
- JMeter-充值-生成随机数
1.随机数,orderId每次需要变化,需要用到随机数 验证生成的随机数: