A954.Sleepy Cow Sorting--Gold
普及/提高-
通过率:0%
时间限制:1.00s
内存限制:128MB
题目描述
Farmer John is attempting to sort his N cows (1≤N≤105),
conveniently numbered 1…N, before they head out to the pastures for
breakfast.
Currently, the cows are standing in a line in the order p1,p2,p3,…,pN, and Farmer John is standing in front of cow p1. He wants to reorder
the cows so that they are in the order 1,2,3,…,N, with cow 1 next
to Farmer John.
Today the cows are a bit sleepy, so at any point in time the only cow who is
paying attention to Farmer John's instructions is the cow directly facing
Farmer John. In one time step, he can instruct this cow to move k paces down
the line, for any k between 1 and N−1 inclusive. The k cows whom she
passes will amble forward, making room for her to insert herself in the line
after them.
For example, suppose that N=4 and the cows start off in the following order:
FJ: 4, 3, 2, 1
The only cow paying attention to FJ is cow 4. If he instructs her to move
2 paces down the line, the order will subsequently look like this:
FJ: 3, 2, 4, 1
Now the only cow paying attention to FJ is cow 3, so in the second time step
he may give cow 3 an instruction, and so forth until the cows are sorted.
Farmer John is eager to complete the sorting, so he can go back to the
farmhouse for his own breakfast. Help him find a sequence of instructions that
sorts the cows in the minimum number of time steps.
输入格式
The first line of input contains N. The second line contains N space-
separated integers: p1,p2,p3,…,pN, indicating the starting order
of the cows.
输出格式
The first line should contain a single integer, K, giving the minimum number
of time steps required to sort the cows.
The second line should contain K space-separated integers, c1,c2,…,cK, each in the range 1…N−1. Furthermore, if in the i-th time
step FJ instructs the cow facing him to move ci paces down the line, then
after K time steps the cows should be in sorted order.
If there are multiple optimal instruction sequences, your program may output
any of them.
输入输出样例
输入#1
4 1 2 4 3
输出#1
3 2 2 3