BestCoder Round #29 GTY's gay friends
#include <cstdio>
#include <cstring>
#include <vector>
#include <algorithm>
using namespace std;
const int MAX = +;
int res[MAX<<],ans[MAX],t[MAX];
int a[MAX],last[MAX];
struct node {
int L,R,id,d;
bool operator <(const node rhs) const {
return R<rhs.R;
}
}v[MAX];
void push_up(int o) {
res[o]=max(res[o<<],res[o<<|]);
}
void build(int L,int R,int o) {
if(L==R) {
res[o]=a[L];
return ;
}
int mid=(L+R)>>;
build(L,mid,o<<);
build(mid+,R,o<<|);
push_up(o);
}
int Query1(int L,int R,int o,int ls,int rs) {
if(ls<=L&&rs>=R) {
return res[o];
} int mid=(L+R)>>;
int tt=;
if(ls<=mid) tt=max(tt,Query1(L,mid,o<<,ls,rs));
if(rs>mid) tt=max(tt,Query1(mid+,R,o<<|,ls,rs));
return tt;
}
int sum[MAX];
int lowbit(int x) {
return x&-x;
}
void modify(int pos,int val) {
for(int i=pos;i<MAX;i+=lowbit(i)) {
sum[i]+=val;
}
}
int Query(int pos) {
int res=;
for(int i=pos;i;i-=lowbit(i)) {
res+=sum[i];
}
return res;
}
int main() {
int n,m;
while(scanf("%d %d",&n,&m)==) {
for(int i=;i<=n;i++) {
scanf("%d",&a[i]);
}
build(,n,);
for(int i=;i<=m;i++) {
scanf("%d %d",&v[i].L,&v[i].R) ;
v[i].id=i;
v[i].d=(v[i].R-v[i].L+);
}
sort(v+,v++m);
memset(sum,,sizeof(sum));
memset(last,,sizeof(last));
int j=; for(int i=;i<=n;i++) {
if(last[a[i]]) {
modify(last[a[i]],-);
}
modify(i,);
last[a[i]]=i;
while(i==v[j].R&&j<=m) { ans[v[j].id]=Query(v[j].R)-Query(v[j].L-);
// printf("%d %d %d\n",ans[v[j].id],v[j].d,Query1(1,n,1,v[j].L,v[j].R));
if(ans[v[j].id]==v[j].d&&Query1(,n,,v[j].L,v[j].R)==v[j].d) {
t[v[j].id]=;
}
else t[v[j].id]=;
j++;
}
}
for(int i=;i<=m;i++) {
if(t[i]) printf("YES\n");
else printf("NO\n");
}
}
return ;
}
BestCoder Round #29 GTY's gay friends的更多相关文章
- BestCoder Round #29 1003 (hdu 5172) GTY's gay friends [线段树 判不同 预处理 好题]
传送门 GTY's gay friends Time Limit: 6000/3000 MS (Java/Others) Memory Limit: 65536/65536 K (Java/Ot ...
- BestCoder Round #29——A--GTY's math problem(快速幂(对数法))、B--GTY's birthday gift(矩阵快速幂)
GTY's math problem Time Limit: 1000/1000 MS (Java/Others) Memory Limit: 65536/65536 K (Java/Other ...
- bestcoder Round #7 前三题题解
BestCoder Round #7 Start Time : 2014-08-31 19:00:00 End Time : 2014-08-31 21:00:00Contest Type : ...
- BestCoder Round #89 02单调队列优化dp
1.BestCoder Round #89 2.总结:4个题,只能做A.B,全都靠hack上分.. 01 HDU 5944 水 1.题意:一个字符串,求有多少组字符y,r,x的下标能组成等比数列 ...
- BestCoder Round #90 //div all 大混战 一题滚粗 阶梯博弈,树状数组,高斯消元
BestCoder Round #90 本次至少暴露出三个知识点爆炸.... A. zz题 按题意copy Init函数 然后统计就ok B. 博弈 题 不懂 推了半天的SG..... 结果这 ...
- Bestcoder round #65 && hdu 5593 ZYB's Tree 树形dp
Time Limit: 3000/1500 MS (Java/Others) Memory Limit: 131072/131072 K (Java/Others)Total Submissio ...
- Bestcoder round #65 && hdu 5592 ZYB's Premutation 线段树
Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 131072/131072 K (Java/Others)Total Submissio ...
- 暴力+降复杂度 BestCoder Round #39 1002 Mutiple
题目传送门 /* 设一个b[]来保存每一个a[]的质因数的id,从后往前每一次更新质因数的id, 若没有,默认加0,nlogn复杂度: 我用暴力竟然水过去了:) */ #include <cst ...
- 贪心 BestCoder Round #39 1001 Delete
题目传送门 /* 贪心水题:找出出现次数>1的次数和res,如果要减去的比res小,那么总的不同的数字tot不会少: 否则再在tot里减去多余的即为答案 用set容器也可以做,思路一样 */ # ...
随机推荐
- AJPFX: Java基础多线程(一)
多线程是Java学习的非常重要的方面,是每个Java程序员必须掌握的基本技能.本文只是多线程细节.本质的总结,并无代码例子入门,不适合初学者理解.初学者学习多线程,建议一边看书.看博文,以便写代码尝试 ...
- 【Hibernate】对应各种数据库的方言
- 一个简单的Java代码生成工具—根据数据源自动生成bean、dao、mapper.xml、service、serviceImpl
目录结构 核心思想 通过properties文件获取数据源—>获取数据表的字段名称.字段类型等—>生成相应的bean实体类(po.model).dao接口(基本的增删改查).mapper. ...
- 博客之旅 gogogo!
听说写博客的人都很牛~ 上班一年多了,想记录点什么,so,就写博客吧,整理一些技术点与工作生活心得 欢迎各位道友交流学习 :)
- Ubuntu14.04环境下java web运行环境搭建
1.jdk安装 将下载好的安装包上传至/home目录解压 tar -zxvf jdk-8u71-linux-x64.tar.gz 执行 vim /etc/profile 在末尾添加java环境变量(J ...
- (转)淘淘商城系列——使用maven tomcat插件启动聚合工程
http://blog.csdn.net/yerenyuan_pku/article/details/72672389 上文我们一起学习了如何使用maven tomcat插件来启动web工程,本文我们 ...
- 【git】搭建git服务器
在 Linux 下搭建 Git 服务器 目录 ① 安装 Git ② 服务器端创建 git 用户,用来管理 Git 服务,并为 git 用户设置密码 ③ 服务器端创建 Git 仓库 ④ 客户端 clon ...
- loadrunner 响应时间和TPS
例子:一个高速路有10个入口,每个入口每秒钟只能进1辆车 1.请问1秒钟最多能进几辆车? TPS=10 2.每辆车需要多长时间进行响应? reponse time = 1 3.改成20辆车 ...
- Zend Studio 离线汉化包下载方法
进入eclipse官网 语言包位置 http://www.eclipse.org/babel/downloads.php
- 【原】CentosDocker安装(一)
CentosDocker安装 来源:https://www.runoob.com/docker/centos-docker-install.html 1.前提条件 目前,CentOS 仅发行版本中的内 ...