codeforces#P933E. A Preponderant Reunion
A Preponderant Reunion
Description
East or west, home is best. That's why family reunion, the indispensable necessity of Lunar New Year celebration, is put in such a position.
After the reunion dinner, Little Tommy plays a game with the family. Here is a concise introduction to this game:
- There is a sequence of n non-negative integers p1, p2, ..., pn in the beginning. It is ruled that each integer in this sequence should be non-negative at any time.
- You can select two consecutive positive integers in this sequence, pi and pi + 1 (1 ≤ i < n), and then decrease them by their minimum (i. e. min(pi, pi + 1)), the cost of this operation is equal to min(pi, pi + 1). We call such operation as a descension.
- The game immediately ends when there are no two consecutive positive integers. Your task is to end the game so that the total cost of your operations is as small as possible.
Obviously, every game ends after at most n - 1 descensions. Please share your solution of this game with the lowest cost.
The first line contains one integer n (1 ≤ n ≤ 3·105).
The second line contains n space-separated integers p1, p2, ..., pn (0 ≤ pi ≤ 109, i = 1, 2, ..., n).
In the first line print one integer as the number of descensions m (0 ≤ m ≤ n - 1).
In the next m lines print the descensions chronologically. More precisely, in each line of the next m lines print one integer i (1 ≤ i < n) representing a descension would operate on pi and pi + 1 such that all the descensions could be utilized from top to bottom.
If there are many possible solutions to reach the minimal cost, print any of them.
Input
The first line contains one integer n (1 ≤ n ≤ 3·105).
The second line contains n space-separated integers p1, p2, ..., pn (0 ≤ pi ≤ 109, i = 1, 2, ..., n).
Output
In the first line print one integer as the number of descensions m (0 ≤ m ≤ n - 1).
In the next m lines print the descensions chronologically. More precisely, in each line of the next m lines print one integer i (1 ≤ i < n) representing a descension would operate on pi and pi + 1 such that all the descensions could be utilized from top to bottom.
If there are many possible solutions to reach the minimal cost, print any of them.
Samples
4
2 1 3 1
2
1
3
5
2 2 1 3 1
3
2
1
4
Note
In the first sample, one possible best solution is , of which the cost is 1 + 1 = 2.
In the second sample, one possible best solution is , of which the cost is 1 + 1 + 1 = 3.