307217: CF1322E. Median Mountain Range

Memory Limit:512 MB Time Limit:2 S
Judge Style:Text Compare Creator:
Submit:0 Solved:0

Description

Median Mountain Range

题意翻译

长度为$n$的序列$a_i$,每次把$[2,n-1]$之间的数变成$\operatorname{median}(a_{i-1},a_i,a_{i+1})$,其中$\operatorname{median}$表示三个数中的中位数。 问多少次操作之后,序列就不再发生变化了。输出序列发生变化的次数,以及最终的序列。 $n \le 500000,1 \le a_i \le 10^9$

题目描述

Berland — is a huge country with diverse geography. One of the most famous natural attractions of Berland is the "Median mountain range". This mountain range is $ n $ mountain peaks, located on one straight line and numbered in order of $ 1 $ to $ n $ . The height of the $ i $ -th mountain top is $ a_i $ . "Median mountain range" is famous for the so called alignment of mountain peaks happening to it every day. At the moment of alignment simultaneously for each mountain from $ 2 $ to $ n - 1 $ its height becomes equal to the median height among it and two neighboring mountains. Formally, if before the alignment the heights were equal $ b_i $ , then after the alignment new heights $ a_i $ are as follows: $ a_1 = b_1 $ , $ a_n = b_n $ and for all $ i $ from $ 2 $ to $ n - 1 $ $ a_i = \texttt{median}(b_{i-1}, b_i, b_{i+1}) $ . The median of three integers is the second largest number among them. For example, $ \texttt{median}(5,1,2) = 2 $ , and $ \texttt{median}(4,2,4) = 4 $ . Recently, Berland scientists have proved that whatever are the current heights of the mountains, the alignment process will stabilize sooner or later, i.e. at some point the altitude of the mountains won't changing after the alignment any more. The government of Berland wants to understand how soon it will happen, i.e. to find the value of $ c $ — how many alignments will occur, which will change the height of at least one mountain. Also, the government of Berland needs to determine the heights of the mountains after $ c $ alignments, that is, find out what heights of the mountains stay forever. Help scientists solve this important problem!

输入输出格式

输入格式


The first line contains integers $ n $ ( $ 1 \le n \le 500\,000 $ ) — the number of mountains. The second line contains integers $ a_1, a_2, a_3, \ldots, a_n $ ( $ 1 \le a_i \le 10^9 $ ) — current heights of the mountains.

输出格式


In the first line print $ c $ — the number of alignments, which change the height of at least one mountain. In the second line print $ n $ integers — the final heights of the mountains after $ c $ alignments.

输入输出样例

输入样例 #1

5
1 2 1 2 1

输出样例 #1

2
1 1 1 1 1

输入样例 #2

6
1 3 2 5 4 6

输出样例 #2

1
1 2 3 4 5 6

输入样例 #3

6
1 1 2 2 1 1

输出样例 #3

0
1 1 2 2 1 1

说明

In the first example, the heights of the mountains at index $ 1 $ and $ 5 $ never change. Since the median of $ 1 $ , $ 2 $ , $ 1 $ is $ 1 $ , the second and the fourth mountains will have height 1 after the first alignment, and since the median of $ 2 $ , $ 1 $ , $ 2 $ is $ 2 $ , the third mountain will have height 2 after the first alignment. This way, after one alignment the heights are $ 1 $ , $ 1 $ , $ 2 $ , $ 1 $ , $ 1 $ . After the second alignment the heights change into $ 1 $ , $ 1 $ , $ 1 $ , $ 1 $ , $ 1 $ and never change from now on, so there are only $ 2 $ alignments changing the mountain heights. In the third examples the alignment doesn't change any mountain height, so the number of alignments changing any height is $ 0 $ .

Input

题意翻译

长度为$n$的序列$a_i$,每次把$[2,n-1]$之间的数变成$\operatorname{median}(a_{i-1},a_i,a_{i+1})$,其中$\operatorname{median}$表示三个数中的中位数。 问多少次操作之后,序列就不再发生变化了。输出序列发生变化的次数,以及最终的序列。 $n \le 500000,1 \le a_i \le 10^9$

加入题单

算法标签: