Alternating Algorithm
문제
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 number of cores, no less!
Incidentally, you also have an array of integers, , 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 and , the third core compares and , the fifth core compares and , and so on. If a pair of compared elements are out of order, the corresponding core will swap their positions. If is even, will be left untouched.
- Even rounds: The second core compares and , the fourth core compares and , the sixth core compares and , and so on. If a pair of compared elements are out of order, the corresponding core will swap their positions. If is odd, will be left untouched, and will be left untouched no matter what the parity of 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 , 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 (), the number of cores and the size of the array.
- One line with integers ( for each ), 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