2855. Minimum Right Shifts to Sort the Array
Description
You are given a 0-indexed array nums of length n containing distinct positive integers. Return the minimum number of right shifts required to sort nums and -1 if this is not possible.
A right shift is defined as shifting the element at index i to index (i + 1) % n, for all indices.
Example 1:
Input: nums = [3,4,5,1,2] Output: 2 Explanation: After the first right shift, nums = [2,3,4,5,1]. After the second right shift, nums = [1,2,3,4,5]. Now nums is sorted; therefore the answer is 2.
Example 2:
Input: nums = [1,3,5] Output: 0 Explanation: nums is already sorted therefore, the answer is 0.
Example 3:
Input: nums = [2,1,4] Output: -1 Explanation: It's impossible to sort the array using right shifts.
Constraints:
1 <= nums.length <= 1001 <= nums[i] <= 100numscontains distinct integers.
Solutions
Solution 1: Direct Traversal
First, we use a pointer \(i\) to traverse the array \(nums\) from left to right, finding a continuous increasing sequence until \(i\) reaches the end of the array or \(nums[i - 1] > nums[i]\). Next, we use another pointer \(k\) to traverse the array \(nums\) from \(i + 1\), finding a continuous increasing sequence until \(k\) reaches the end of the array or \(nums[k - 1] > nums[k]\) and \(nums[k] > nums[0]\). If \(k\) reaches the end of the array, it means the array is already increasing, so we return \(n - i\); otherwise, we return \(-1\).
The time complexity is \(O(n)\), and the space complexity is \(O(1)\). Here, \(n\) is the length of the array \(nums\).
1 2 3 4 5 6 7 8 9 10 | |
1 2 3 4 5 6 7 8 9 10 11 12 13 14 | |
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 | |
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 | |
1 2 3 4 5 6 7 8 9 10 11 12 | |