No tag edit access

A. Ilya and Diplomas

time limit per test

1 secondmemory limit per test

256 megabytesinput

standard inputoutput

standard outputSoon a school Olympiad in Informatics will be held in Berland, *n* schoolchildren will participate there.

At a meeting of the jury of the Olympiad it was decided that each of the *n* participants, depending on the results, will get a diploma of the first, second or third degree. Thus, each student will receive exactly one diploma.

They also decided that there must be given at least *min*_{1} and at most *max*_{1} diplomas of the first degree, at least *min*_{2} and at most *max*_{2} diplomas of the second degree, and at least *min*_{3} and at most *max*_{3} diplomas of the third degree.

After some discussion it was decided to choose from all the options of distributing diplomas satisfying these limitations the one that maximizes the number of participants who receive diplomas of the first degree. Of all these options they select the one which maximizes the number of the participants who receive diplomas of the second degree. If there are multiple of these options, they select the option that maximizes the number of diplomas of the third degree.

Choosing the best option of distributing certificates was entrusted to Ilya, one of the best programmers of Berland. However, he found more important things to do, so it is your task now to choose the best option of distributing of diplomas, based on the described limitations.

It is guaranteed that the described limitations are such that there is a way to choose such an option of distributing diplomas that all *n* participants of the Olympiad will receive a diploma of some degree.

Input

The first line of the input contains a single integer *n* (3 ≤ *n* ≤ 3·10^{6}) — the number of schoolchildren who will participate in the Olympiad.

The next line of the input contains two integers *min*_{1} and *max*_{1} (1 ≤ *min*_{1} ≤ *max*_{1} ≤ 10^{6}) — the minimum and maximum limits on the number of diplomas of the first degree that can be distributed.

The third line of the input contains two integers *min*_{2} and *max*_{2} (1 ≤ *min*_{2} ≤ *max*_{2} ≤ 10^{6}) — the minimum and maximum limits on the number of diplomas of the second degree that can be distributed.

The next line of the input contains two integers *min*_{3} and *max*_{3} (1 ≤ *min*_{3} ≤ *max*_{3} ≤ 10^{6}) — the minimum and maximum limits on the number of diplomas of the third degree that can be distributed.

It is guaranteed that *min*_{1} + *min*_{2} + *min*_{3} ≤ *n* ≤ *max*_{1} + *max*_{2} + *max*_{3}.

Output

In the first line of the output print three numbers, showing how many diplomas of the first, second and third degree will be given to students in the optimal variant of distributing diplomas.

The optimal variant of distributing diplomas is the one that maximizes the number of students who receive diplomas of the first degree. Of all the suitable options, the best one is the one which maximizes the number of participants who receive diplomas of the second degree. If there are several of these options, the best one is the one that maximizes the number of diplomas of the third degree.

Examples

Input

6

1 5

2 6

3 7

Output

1 2 3

Input

10

1 2

1 3

1 5

Output

2 3 5

Input

6

1 3

2 2

2 2

Output

2 2 2

Codeforces (c) Copyright 2010-2017 Mike Mirzayanov

The only programming contests Web 2.0 platform

Server time: Dec/18/2017 04:16:08 (c6).

Desktop version, switch to mobile version.

User lists

Name |
---|