Hide

Problem J
Rhythm Flow

You are designing a scoring algorithm for the new hit rhythm game Rhythm Flow where players must press a button in time to the music. During a round of Rhythm Flow, there are points in time when a visual indicator flashes on the screen. Players are expected to press the button at those times (and only at those times). However, since human reaction time is not instantaneous, the game gives the player some leeway and accepts a button press a few milliseconds earlier or later than expected. More accurate presses are worth more points.

The following table lists how many points a player gets depending on how far away the actual button press is from the expected button press, in milliseconds:

Time Difference (ms)

Points

$[0, 15]$

7

$(15, 23]$

6

$(23, 43]$

4

$(43, 102]$

2

Wildly inaccurate presses with a difference of $103$ milliseconds or more score no points.

During gameplay, the player presses the button some number of times. To score the game, match each actual button press with at most one expected button press, with the following restriction: if one actual button press happens before another actual button press and both button presses are matched with expected button presses, then the expected button press for the first must be strictly before the expected button press for the second.

Because you are generous, you decide to compute the matching that maximizes the number of points the player earns. Compute the final score of the round of Rhythm Flow under this matching.

Input

The first line contains two integers $n$ and $m$ ($1 \le n, m \le 2\, 000$), where $n$ is the number of expected button presses and $m$ is the number of actual button presses.

Each of the next $n$ lines contains a single integer $e$ ($1 \le e \le 10^9$). These are the times of the expected button presses in milliseconds from the start of the round. It is guaranteed that these values are unique and in sorted order.

Each of the next $m$ lines contains a single integer $a$ ($1 \le a \le 10^9$). These are the times of the actual button presses in milliseconds from the start of the round. It is guaranteed that these values are unique and in sorted order.

Output

Output a single integer: the total number of points the player earns given a maximally-generous scoring engine.

Sample Input 1 Sample Output 1
3 4
100
200
300
99
201
240
323
20
Sample Input 2 Sample Output 2
4 3
1000
2000
2500
3000
1103
2598
4000
2
Sample Input 3 Sample Output 3
2 2
100
144
56
100
7

Please log in to submit a solution to this problem

Log in