A800.Farmer John Solves 3SUM--Gold
提高+/省选-
通过率:0%
时间限制:1.00s
内存限制:128MB
题目描述
Farmer John believes he has made a major breakthrough in algorithm design: he
claims to have found a nearly linear time algorithm for the 3SUM problem, an
algorithmic problem famous for the fact that no known solution exists running
in substantially better than quadratic time. One formulation of the 3SUM
problem is the following: given an array s1,…,sm of integers, count
the number of unordered triples of distinct indices i,j,k such that si+sj+sk=0.
To test Farmer John's claim, Bessie has provided an array A of N integers
(1≤N≤5000). Bessie also asks Q queries (1≤Q≤105),
each of which consists of two indices 1≤ai≤bi≤N. For each
query, Farmer John must solve the 3SUM problem on the subarray A[ai…bi].
Unfortunately, Farmer John has just discovered a flaw in his algorithm. He is
confident that he can fix the algorithm, but in the meantime, he asks that you
help him pass Bessie's test!
输入格式
The first line contains two space-separated integers N and Q. The second
line contains the space-separated elements A1,…,AN of array A. Each
of the subsequent Q lines contains two space-separated integers ai and
bi, representing a query.
It is guaranteed that −106≤Ai≤106 for every array element
Ai.
输出格式
The output should consist of Q lines, with each line i containing a single
integer---the answer to the i-th query. Note that you should use 64-bit
integers to avoid overflow.
输入输出样例
输入#1
7 3 2 0 -1 1 -2 3 3 1 5 2 4 1 7
输出#1
2 1 4