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. Polycarp's problems

time limit per test

2 secondsmemory limit per test

256 megabytesinput

standard inputoutput

standard outputPolycarp is an experienced participant in Codehorses programming contests. Now he wants to become a problemsetter.

He sent to the coordinator a set of *n* problems. Each problem has it's quality, the quality of the *i*-th problem is *a*_{i} (*a*_{i} can be positive, negative or equal to zero). The problems are ordered by expected difficulty, but the difficulty is not related to the quality in any way. The easiest problem has index 1, the hardest problem has index *n*.

The coordinator's mood is equal to *q* now. After reading a problem, the mood changes by it's quality. It means that after the coordinator reads a problem with quality *b*, the value *b* is added to his mood. The coordinator always reads problems one by one from the easiest to the hardest, it's impossible to change the order of the problems.

If after reading some problem the coordinator's mood becomes negative, he immediately stops reading and rejects the problemset.

Polycarp wants to remove the minimum number of problems from his problemset to make the coordinator's mood non-negative at any moment of time. Polycarp is not sure about the current coordinator's mood, but he has *m* guesses "the current coordinator's mood *q* = *b*_{i}".

For each of *m* guesses, find the minimum number of problems Polycarp needs to remove so that the coordinator's mood will always be greater or equal to 0 while he reads problems from the easiest of the remaining problems to the hardest.

Input

The first line of input contains two integers *n* and *m* (1 ≤ *n* ≤ 750, 1 ≤ *m* ≤ 200 000) — the number of problems in the problemset and the number of guesses about the current coordinator's mood.

The second line of input contains *n* integers *a*_{1}, *a*_{2}, ..., *a*_{n} ( - 10^{9} ≤ *a*_{i} ≤ 10^{9}) — the qualities of the problems in order of increasing difficulty.

The third line of input contains *m* integers *b*_{1}, *b*_{2}, ..., *b*_{m} (0 ≤ *b*_{i} ≤ 10^{15}) — the guesses of the current coordinator's mood *q*.

Output

Print *m* lines, in *i*-th line print single integer — the answer to the problem with *q* = *b*_{i}.

Example

Input

6 3

8 -5 -4 1 -7 4

0 7 3

Output

2

0

1

Codeforces (c) Copyright 2010-2019 Mike Mirzayanov

The only programming contests Web 2.0 platform

Server time: Oct/15/2019 11:02:54 (e1).

Desktop version, switch to mobile version.

Supported by

User lists

Name |
---|