Please, try EDU on Codeforces! New educational section with videos, subtitles, texts, and problems.
×

Virtual contest is a way to take part in past contest, as close as possible to participation on time. It is supported only 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

F. Ann and Books

time limit per test

2 secondsmemory limit per test

256 megabytesinput

standard inputoutput

standard outputIn Ann's favorite book shop are as many as *n* books on math and economics. Books are numbered from 1 to *n*. Each of them contains non-negative number of problems.

Today there is a sale: any subsegment of a segment from *l* to *r* can be bought at a fixed price.

Ann decided that she wants to buy such non-empty subsegment that the sale operates on it and the number of math problems is greater than the number of economics problems exactly by *k*. Note that *k* may be positive, negative or zero.

Unfortunately, Ann is not sure on which segment the sale operates, but she has *q* assumptions. For each of them she wants to know the number of options to buy a subsegment satisfying the condition (because the time she spends on choosing depends on that).

Currently Ann is too busy solving other problems, she asks you for help. For each her assumption determine the number of subsegments of the given segment such that the number of math problems is greaten than the number of economics problems on that subsegment exactly by *k*.

Input

The first line contains two integers *n* and *k* (1 ≤ *n* ≤ 100 000, - 10^{9} ≤ *k* ≤ 10^{9}) — the number of books and the needed difference between the number of math problems and the number of economics problems.

The second line contains *n* integers *t* _{1}, *t* _{2}, ..., *t* _{ n} (1 ≤ *t* _{ i} ≤ 2), where *t* _{ i} is 1 if the *i*-th book is on math or 2 if the *i*-th is on economics.

The third line contains *n* integers *a* _{1}, *a* _{2}, ..., *a* _{ n} (0 ≤ *a* _{ i} ≤ 10^{9}), where *a* _{ i} is the number of problems in the *i*-th book.

The fourth line contains a single integer *q* (1 ≤ *q* ≤ 100 000) — the number of assumptions.

Each of the next *q* lines contains two integers *l* _{ i} and *r* _{ i} (1 ≤ *l* _{ i} ≤ *r* _{ i} ≤ *n*) describing the *i*-th Ann's assumption.

Output

Print *q* lines, in the *i*-th of them print the number of subsegments for the *i*-th Ann's assumption.

Examples

Input

4 1

1 1 1 2

1 1 1 1

4

1 2

1 3

1 4

3 4

Output

2

3

4

1

Input

4 0

1 2 1 2

0 0 0 0

1

1 4

Output

10

Note

In the first sample Ann can buy subsegments [1;1], [2;2], [3;3], [2;4] if they fall into the sales segment, because the number of math problems is greater by 1 on them that the number of economics problems. So we should count for each assumption the number of these subsegments that are subsegments of the given segment.

Segments [1;1] and [2;2] are subsegments of [1;2].

Segments [1;1], [2;2] and [3;3] are subsegments of [1;3].

Segments [1;1], [2;2], [3;3], [2;4] are subsegments of [1;4].

Segment [3;3] is subsegment of [3;4].

Codeforces (c) Copyright 2010-2020 Mike Mirzayanov

The only programming contests Web 2.0 platform

Server time: Jul/08/2020 14:54:25 (f1).

Desktop version, switch to mobile version.

Supported by

User lists

Name |
---|