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

2482. [Spoj1557] Can you answer these queries II

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

题目描述

给定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