博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
hdu 5172 GTY's gay friends 线段树
阅读量:6208 次
发布时间:2019-06-21

本文共 1979 字,大约阅读时间需要 6 分钟。

GTY's gay friends

 问题描述
GTY有n个基友,出于某种恶趣味,GTY每天早上会让他的基友们排成一行,每个基友有一个特征值,表示基友有多雄壮或娘炮,你,作为GTY的助手,必须回答GTY的每个询问,GTY每次会问一个区间[l,r][l,r]是否为一个11到r-l+1r−l+1的排列。
输入描述
多组数据(约3组),每组数据的第一行有两个数n,m(1 \leq n,m \leq 100000)n,m(1≤n,m≤100000) 表示初始基友数量和询问个数,第二行包含nn个数a_i (1 \leq a_i \leq n)ai(1≤ai≤n)表示基友的特征值,接下来mm行每行两个数l,rl,r表示询问[l,r][l,r]是否为一个排列。
输出描述
对于每个询问,若它是一个排列,输出”YES”,否则输出”NO”
输入样例
8 52 1 3 4 5 2 3 11 31 12 24 81 53 21 1 11 11 2
输出样例
YESNOYESYESYESYESNO
 如果区间(l,r)是一个排列,那么必须满足两个条件
 1.区间之中的数之和等于len*(len+1)/2 自然数之和公式
 2.区间中没有重复的数
 第一个条件用前缀和进行判断,第二个条件利用pre数组进行判断,pre代表数ai上次出现的位置
如果这个区间中最大的pre都小于l,那么这个区间内就一定没有重复的数,反之则一定有重复的数
使用线段树进行求rmq,建树O(n),查询O(logn)
 
 
#include 
#include
#include
using namespace std;typedef long long LL;const int Max=1e6+10;LL sum[Max];int maxv[Max*4];int map[Max];int pre[Max];//标记传递void PushUp(int root){ maxv[root]=max(maxv[root<<1],maxv[root<<1|1]);}//建立线段树void Build(int l,int r,int root){ if(l==r) maxv[root]=pre[l]; else { int mid=(l+r)>>1; Build(l,mid,root<<1); Build(mid+1,r,root<<1|1); PushUp(root); }}//查询int Query(int ql,int qr,int l,int r,int root){ if(ql<=l&&qr>=r) return maxv[root]; int mid=(l+r)>>1; int ans=-1; if(ql<=mid) ans=max(ans,Query(ql,qr,l,mid,root<<1)); if(qr>mid) ans=max(ans,Query(ql,qr,mid+1,r,root<<1|1)); return ans;}int main(){ int n,m,x,l,r; while(~scanf("%d%d",&n,&m)) { memset(map,-1,sizeof(map)); for(int i=1;i<=n;i++) { scanf("%d",&x); i==1?sum[i]=x:sum[i]=sum[i-1]+x; pre[i]=map[x]; map[x]=i; } Build(1,n,1); while(m--) { scanf("%d%d",&l,&r); LL len=r-l+1; if(sum[r]-sum[l-1]!=len*(len+1)/2) { puts("NO"); continue; } if(Query(l,r,1,n,1)
View Code

 

 

转载于:https://www.cnblogs.com/zsyacm666666/p/5379896.html

你可能感兴趣的文章
android多渠道打包
查看>>
【Spring系列】自己手写一个 SpringMVC 框架
查看>>
Microsoft Visual Studio WPF项目 错误:未处理 SecurityException,PublicKeyToken=b77a5c561934e089...
查看>>
在grid结果集中实现全选或全不选某些特定的行
查看>>
bzoj1212[HNOI2004]L语言
查看>>
bzoj1622[Usaco2008 Open]Word Power 名字的能量*
查看>>
uitableview做九宫格
查看>>
相同的树
查看>>
tcl使用笔记
查看>>
退役前留帖
查看>>
二叉树的遍历
查看>>
C入门语言基础一[可移植性、涉及的三种文件、编程7个步骤、编译器、链接器]...
查看>>
Python3抓取 深圳房地产均价数据,通过真实数据为购置不动产做决策分析(一)...
查看>>
Rotating an array in place
查看>>
PL/SQL实现JAVA中的split()方法的小例子
查看>>
SOFARPC源码解析-搭建环境
查看>>
FreeBSd ports 安装软件
查看>>
Fast inverse square root
查看>>
FAQ: SBS 2011. The Windows SBS Manager service terminated unexpectedly
查看>>
判断一个坐标点是否在不规则多边形内部的算法
查看>>