Virtual contest is a way to take part in past contest, as close as possible to participation on time. It is supported only ACM-ICPC mode for virtual contests.
If you've seen these problems, a virtual contest is not for you - solve these problems in the archive.
If you just want to solve some problem from a contest, a virtual contest is not for you - solve this problem in the archive.
Never use someone else's code, read the tutorials or communicate with other person during a virtual contest.

No tag edit access

C. Boredom

time limit per test

2 secondsmemory limit per test

512 megabytesinput

standard inputoutput

standard outputIlya is sitting in a waiting area of Metropolis airport and is bored of looking at time table that shows again and again that his plane is delayed. So he took out a sheet of paper and decided to solve some problems.

First Ilya has drawn a grid of size *n* × *n* and marked *n* squares on it, such that no two marked squares share the same row or the same column. He calls a rectangle on a grid with sides parallel to grid sides beautiful if exactly two of its corner squares are marked. There are exactly *n*·(*n* - 1) / 2 beautiful rectangles.

Ilya has chosen *q* query rectangles on a grid with sides parallel to grid sides (not necessarily beautiful ones), and for each of those rectangles he wants to find its beauty degree. Beauty degree of a rectangle is the number of beautiful rectangles that share at least one square with the given one.

Now Ilya thinks that he might not have enough time to solve the problem till the departure of his flight. You are given the description of marked cells and the query rectangles, help Ilya find the beauty degree of each of the query rectangles.

Input

The first line of input contains two integers *n* and *q* (2 ≤ *n* ≤ 200 000, 1 ≤ *q* ≤ 200 000) — the size of the grid and the number of query rectangles.

The second line contains *n* integers *p*_{1}, *p*_{2}, ..., *p*_{n}, separated by spaces (1 ≤ *p*_{i} ≤ *n*, all *p*_{i} are different), they specify grid squares marked by Ilya: in column *i* he has marked a square at row *p*_{i}, rows are numbered from 1 to *n*, bottom to top, columns are numbered from 1 to *n*, left to right.

The following *q* lines describe query rectangles. Each rectangle is described by four integers: *l*, *d*, *r*, *u* (1 ≤ *l* ≤ *r* ≤ *n*, 1 ≤ *d* ≤ *u* ≤ *n*), here *l* and *r* are the leftmost and the rightmost columns of the rectangle, *d* and *u* the bottommost and the topmost rows of the rectangle.

Output

For each query rectangle output its beauty degree on a separate line.

Examples

Input

2 3

1 2

1 1 1 1

1 1 1 2

1 1 2 2

Output

1

1

1

Input

4 2

1 3 2 4

4 1 4 4

1 1 2 3

Output

3

5

Note

The first sample test has one beautiful rectangle that occupies the whole grid, therefore the answer to any query is 1.

In the second sample test the first query rectangle intersects 3 beautiful rectangles, as shown on the picture below:

There are 5 beautiful rectangles that intersect the second query rectangle, as shown on the following picture:

Codeforces (c) Copyright 2010-2019 Mike Mirzayanov

The only programming contests Web 2.0 platform

Server time: Jun/25/2019 21:44:04 (f3).

Desktop version, switch to mobile version.

Supported by

User lists

Name |
---|