Hide

Problem C
Social Distancing

It’s time for a social distancing party! A group of friends are sitting around a circular table where some seats are filled and some seats are empty. In particular, to maintain social distancing protocols, no two people are sitting directly beside each other.

They want to expand the party and include more friends, but no one is willing to move out of their current seat. Given the current table seating, determine the maximum number of additional people that can be seated such that there is still at least one empty seat between all pairs of people seated.

Input

The first line of input contains two integers $S$ ($3 \leq S \leq 1\, 000$), which is the number of seats at the table, and $N$ ($1 \leq N \leq S/2$), which is the number of people that are already seated at the table.

Note that the seats of the table are numbered $1, 2, \ldots , S$ in a circular fashion: for each $1 \leq i < S$, seats numbered $i$ and $i+1$ are directly beside each other. Seats $S$ and $1$ are also directly beside each other.

The second line contains $N$ integers $a_1, a_2, \ldots , a_ N$ ($1 \leq a_1 < a_2 < \cdots < a_ N \leq S$), which indicates that seat number $a_{i}$ is currently occupied. No two occupied seats are directly beside each other.

Output

Display the maximum number of additional friends that can be seated at the table such that there is still at least one empty seat between all pairs of people seated.

Sample Input 1 Sample Output 1
9 2
2 6
2
Sample Input 2 Sample Output 2
10 3
1 4 7
1
Sample Input 3 Sample Output 3
6 2
2 5
0
Sample Input 4 Sample Output 4
100 5
7 14 47 78 99
43
Sample Input 5 Sample Output 5
6 1
3
2

Please log in to submit a solution to this problem

Log in