PivotOJ

Alternating Algorithm

시간 제한: 7000ms메모리 제한: 1024MB출처: NWERC 2022BOJ 26174

문제

In recent years, CPU manufacturers have found it increasingly difficult to keep up with Moore's law of doubling the number of transistors on integrated circuit chips every two years. To address this, manufacturers have instead started creating CPUs with an increasingly higher number of cores. In fact, you just purchased a CPU with a staggering nn number of cores, no less!

Incidentally, you also have an array of n+1n+1 integers, a0,a1,,ana_0, a_1, \ldots, a_n, that you need to sort. To make good use of the large number of cores on your CPU, you have devised a parallel sorting algorithm in which there is a dedicated core for comparing each adjacent pair of integers. As long as the array is not sorted in non-decreasing order, the algorithm proceeds in rounds that alternate between:

  • Odd rounds (starting with the first): The first core compares a0a_0 and a1a_1, the third core compares a2a_2 and a3a_3, the fifth core compares a4a_4 and a5a_5, and so on. If a pair of compared elements are out of order, the corresponding core will swap their positions. If nn is even, ana_n will be left untouched.
  • Even rounds: The second core compares a1a_1 and a2a_2, the fourth core compares a3a_3 and a4a_4, the sixth core compares a5a_5 and a6a_6, and so on. If a pair of compared elements are out of order, the corresponding core will swap their positions. If nn is odd, ana_n will be left untouched, and a0a_0 will be left untouched no matter what the parity of nn is.

Note that in both types of rounds some cores may be idle.

Before implementing this algorithm, you have decided to do some analysis. In particular, you noticed that the time complexity of the algorithm does not depend on the value of nn, but rather it depends on the number of rounds that the algorithm runs. Given the initial contents of the array, determine the number of rounds that the parallel sorting algorithm runs before the array becomes sorted.

입력

The input consists of:

  • One line with an integer nn (1n41051 \leq n \leq 4\cdot10^5), the number of cores and the size of the array.
  • One line with n+1n+1 integers a0,a1,,ana_0, a_1, \ldots, a_n (0ai1090 \leq a_i \leq 10^9 for each ii), the initial contents of the array.

출력

Output the number of rounds that the parallel sorting algorithm runs before the array becomes sorted in non-decreasing order.

예제

예제 1

입력
3
8 13 4 10
출력
3

예제 2

입력
5
13 12 14 10 14 12
출력
3

예제 3

입력
2
2 2 1
출력
3
코드를 제출하려면 로그인하세요.