题目描述
现有数列 A1,A2,...,AN,QQ 个询问 (Li,Ri),询问 ALi,ALi+1,...,ARi 是否互不相同。
输入格式
第一行,两个整数N,Q。
第二行,NN 个整数A1,A2,...,AN。
接下来 QQ 行,每行两个整数 Li,Ri。
输出格式
对每个询问输出一行,Yes
或 No
。
输入输出样例
输入 #1复制
4 2
1 2 3 2
1 3
2 4
输出 #1复制
Yes
No
说明/提示
对于 50% 的数据,N,Q≤103。
对于 100%的数据,1≤N,Q≤105,1≤Ai≤N,1≤Li≤Ri≤N。
思路:
很显然,这道题我们可以用莫队做,但是我不会对新手不友好,所以这里用了一种简单的方法水过去。
首先a[i]为i最后出现的位置,m[i]为数列中第1位到第i位最早的出现的不重复字串第一个字符的位置。
举个例子:(下标以1开始)
1 3 4 5 4时
a[2]=5
m[5]=2
懂了吗?没懂算了
所以 st[i]=max(st[i-1],last[x]+1)
Code:
cpp
#include<bits/stdc++.h>
using namespace std;
int a[100005],m[100005],n,q,k,l,r;
int main(){
cin>>n>>q;
for(int i=1;i<=n;i++){
cin>>k;
m[i]=max(m[i-1],a[k]+1);
a[k]=i;
}
for(int i=1;i<=q;i++){
cin>>l>>r;
if(m[r]<=l)cout<<"Yes\n";
else cout<<"No\n";
}
}