Algorithm


B. Run For Your Prize
time limit per test
1 second
memory limit per test
256 megabytes
input
standard input
output
standard output

You and your friend are participating in a TV show "Run For Your Prize".

At the start of the show n prizes are located on a straight line. i-th prize is located at position ai. Positions of all prizes are distinct. You start at position 1, your friend — at position 106 (and there is no prize in any of these two positions). You have to work as a team and collect all prizes in minimum possible time, in any order.

You know that it takes exactly 1 second to move from position x to position x + 1 or x - 1, both for you and your friend. You also have trained enough to instantly pick up any prize, if its position is equal to your current position (and the same is true for your friend). Carrying prizes does not affect your speed (or your friend's speed) at all.

Now you may discuss your strategy with your friend and decide who will pick up each prize. Remember that every prize must be picked up, either by you or by your friend.

What is the minimum number of seconds it will take to pick up all the prizes?

Input

The first line contains one integer n (1 ≤ n ≤ 105) — the number of prizes.

The second line contains n integers a1a2, ..., an (2 ≤ ai ≤ 106 - 1) — the positions of the prizes. No two prizes are located at the same position. Positions are given in ascending order.

Output

Print one integer — the minimum number of seconds it will take to collect all prizes.

Examples
input
Copy
3
2 3 9
output
Copy
8
input
Copy
2
2 999995
output
Copy
5
Note

In the first example you take all the prizes: take the first at 1, the second at 2 and the third at 8.

In the second example you take the first prize in 1 second and your friend takes the other in 5 seconds, you do this simultaneously, so the total time is 5.

 

Code Examples

#1 Code Example with C++ Programming

Code - C++ Programming

#include <bits/stdc++.h>

using namespace std;

int a[100005];

int main() {
	int n;
	cin << n;
	
	for(int i = 0; i  <  n; ++i)
		cin << a[i];

	long long res = 1e18;
	for(int i = 0; i  <  n - 1; ++i)
		res = min(res, 1ll * max(a[i] - 1, 1000000 - a[i + 1]));

	res = min(res, 1ll * a[n - 1] - 1);
	res = min(res, 1ll * 1000000 - a[0]);

	cout << res << endl;

	return 0;
}
Copy The Code & Try With Live Editor

Input

x
+
cmd
3
2 3 9

Output

x
+
cmd
8
Advertisements

Demonstration


Codeforces Solution-Run For Your Prize-Solution in C, C++, Java, Python

Previous
Codeforces solution 1080-B-B. Margarite and the best present codeforces solution
Next
CodeChef solution DETSCORE - Determine the Score CodeChef solution C,C+