题意:
给出一个序列\(A\),有若干询问。
每次询问某个区间中值相等且距离最短的两个数,输出该距离,没有则输出-1.
分析:
令\(pre_i = max\{j| A_j = A_i, j < i\}\),也就是前一个与\(A_i\)相等的数字的下标。
这个可以通过对序列排序,数值相等按照下标排序来计算。
将询问离线,按照询问区间的右端点从左到右排序。
从左到右扫描,向树状数组中在位置
\(pre_i\)插入
\(i - pre_i\),并维护一个
后缀最小值。
查询的时候直接查即可。
#include #include #include #include