Source : 信息学奥赛一本通
Description
A是某公司的CEO,每个月都会有员工把公司的盈利数据送给A,A是个与众不同的怪人,A不注重盈利还是亏本,而是喜欢研究“完美序列”:连续的互不相同的序列。A想知道区间[L,R]之间最长的完美序列。
Input
第一行两个整数N,M(1<=N,M<=200000),N表示连续N个月,编号为0到N-1,M表示询问的次数。第二行N个整数(绝对值不超过106),第i个数表示该公司第i个月的盈利值。接下来M行每行两个整数L,R(0<=L<=R<=N-1),表示A询问的区间。
Output
输出M行,每行一个整数对应询问区间内的完美序列的最长长度。
Sample Input
9 2
2 5 4 1 2 3 6 2 4
0 8
2 6
4 8 
Sample Output
6
5
4 
Hint
设last[x]为数x当前最近出现的位置,st[i]为以第i个数为终点的最长完美序列的起点序号,q[i]表示以第i个数为终点的最长完美序列的长度,可以写出:
for i:=1 to n do begin read(a[i]);
  st[i]:=max(st[i-1],last[a[i]]+1); q[i]:=i-st[i]+1; last[a[i]]:=i;
end;