Wave Sort
Learn how to solve the 'Wave Sort' problem. This detailed resource details brute force and optimized approaches.
Problem Statement
Write a function wave_sort(arr) that takes an array of integers arr, sorts it in ascending order, and then swaps every adjacent pair of elements starting from index 0 (i.e., swap arr[0] and arr[1], then arr[2] and arr[3], and so on) to produce a wave-sorted array satisfying the property arr[0] >= arr[1] <= arr[2] >= arr[3] <= arr[4].... Return the resulting array.
- •1 <= len(arr) <= 10^5
- •-10^9 <= arr[i] <= 10^9
Examples
wave_sort([3, 6, 5, 10, 7, 20])
[5, 3, 7, 6, 20, 10]
First, sort the array to get [3, 5, 6, 7, 10, 20]. Swapping adjacent pairs: swap 3 and 5 -> [5, 3...], swap 6 and 7 -> [..., 7, 6...], swap 10 and 20 -> [..., 20, 10]. Result is [5, 3, 7, 6, 20, 10].
wave_sort([10, 90, 49, 2, 1, 5, 23])
[2, 1, 10, 5, 49, 23, 90]
Sort array to [1, 2, 5, 10, 23, 49, 90]. Swapping adjacent pairs gives [2, 1, 10, 5, 49, 23, 90].
Need a Hint?
Edge Cases to Watch
- Empty list or null input variables
- Single item lists/arrays
- Extremely large input bounds causing integer or stack overflow
Ready to Solve?
Open the problem in PyRun's browser-based Python editor. Your code runs fully offline — no server required.