#2482. [Spoj1557] Can you answer these queries II

内存限制:128 MiB 时间限制:20 Sec

题目描述

给定n个元素的序列。
给出m个询问:求l[i]~r[i]的最大子段和(可选空子段)。
这个最大子段和有点特殊:一个数字在一段中出现了两次只算一次。
比如:1,2,3,2,2,2出现了3次,但只算一次,于是这个序列的和是1+2+3=6。

输入格式

 

第一行一个数n。
第二行n个数,为给定的序列,这些数的绝对值小于等于100000。
第三行一个数m。
接下来m行,每行两个数,l[i],r[i]。

输出格式

M行,每行一个数,为每个询问的答案。


样例

样例输入


			
9
4 -2 -2 3 -1 -4 2 2 -6
3
1 2
1 5
4 9


样例输出


			

4
5
3

数据范围与提示

【数据说明】

30%:1 <= n, m <= 100

100%:1 <= n, m <= 100000