912. Sort an Array LeetCode Solution
In this guide, you will get 912. Sort an Array LeetCode Solution with the best time and space complexity. The solution to Sort an Array problem is provided in various programming languages like C++, Java, and Python. This will be helpful for you if you are preparing for placements, hackathons, interviews, or practice purposes. The solutions provided here are very easy to follow and include detailed explanations.
Table of Contents
- Problem Statement
- Complexity Analysis
- Sort an Array solution in C++
- Sort an Array solution in Java
- Sort an Array solution in Python
- Additional Resources
data:image/s3,"s3://crabby-images/ed848/ed848825b15498784be40354e8b363d5ab19cca6" alt="912. Sort an Array LeetCode Solution 912. Sort an Array LeetCode Solution image"
Problem Statement of Sort an Array
Given an array of integers nums, sort the array in ascending order and return it.
You must solve the problem without using any built-in functions in O(nlog(n)) time complexity and with the smallest space complexity possible.
Example 1:
Input: nums = [5,2,3,1]
Output: [1,2,3,5]
Explanation: After sorting the array, the positions of some numbers are not changed (for example, 2 and 3), while the positions of other numbers are changed (for example, 1 and 5).
Example 2:
Input: nums = [5,1,1,2,0,0]
Output: [0,0,1,1,2,5]
Explanation: Note that the values of nums are not necessairly unique.
Constraints:
1 <= nums.length <= 5 * 104
-5 * 104 <= nums[i] <= 5 * 104
Complexity Analysis
- Time Complexity: O(n\log n)
- Space Complexity: O(n)
912. Sort an Array LeetCode Solution in C++
class Solution {
public:
vector<int> sortArray(vector<int>& nums) {
mergeSort(nums, 0, nums.size() - 1);
return nums;
}
private:
void mergeSort(vector<int>& nums, int l, int r) {
if (l >= r)
return;
const int m = (l + r) / 2;
mergeSort(nums, l, m);
mergeSort(nums, m + 1, r);
merge(nums, l, m, r);
}
void merge(vector<int>& nums, int l, int m, int r) {
vector<int> sorted(r - l + 1);
int k = 0; // sorted's index
int i = l; // left's index
int j = m + 1; // right's index
while (i <= m && j <= r)
if (nums[i] < nums[j])
sorted[k++] = nums[i++];
else
sorted[k++] = nums[j++];
// Put the possible remaining left part into the sorted array.
while (i <= m)
sorted[k++] = nums[i++];
// Put the possible remaining right part into the sorted array.
while (j <= r)
sorted[k++] = nums[j++];
copy(sorted.begin(), sorted.end(), nums.begin() + l);
}
};
/* code provided by PROGIEZ */
912. Sort an Array LeetCode Solution in Java
class Solution {
public int[] sortArray(int[] nums) {
mergeSort(nums, 0, nums.length - 1);
return nums;
}
private void mergeSort(int[] nums, int l, int r) {
if (l >= r)
return;
final int m = (l + r) / 2;
mergeSort(nums, l, m);
mergeSort(nums, m + 1, r);
merge(nums, l, m, r);
}
private void merge(int[] nums, int l, int m, int r) {
int[] sorted = new int[r - l + 1];
int k = 0; // sorted's index
int i = l; // left's index
int j = m + 1; // right's index
while (i <= m && j <= r)
if (nums[i] < nums[j])
sorted[k++] = nums[i++];
else
sorted[k++] = nums[j++];
// Put the possible remaining left part into the sorted array.
while (i <= m)
sorted[k++] = nums[i++];
// Put the possible remaining right part into the sorted array.
while (j <= r)
sorted[k++] = nums[j++];
System.arraycopy(sorted, 0, nums, l, sorted.length);
}
}
// code provided by PROGIEZ
912. Sort an Array LeetCode Solution in Python
class Solution:
def sortArray(self, nums: list[int]) -> list[int]:
self._mergeSort(nums, 0, len(nums) - 1)
return nums
def _mergeSort(self, nums: list[int], l: int, r: int) -> None:
if l >= r:
return
def merge(nums: list[int], l: int, m: int, r: int) -> None:
sorted = [0] * (r - l + 1)
k = 0 # sorted's index
i = l # left's index
j = m + 1 # right's index
while i <= m and j <= r:
if nums[i] < nums[j]:
sorted[k] = nums[i]
k += 1
i += 1
else:
sorted[k] = nums[j]
k += 1
j += 1
# Put the possible remaining left part into the sorted array.
while i <= m:
sorted[k] = nums[i]
k += 1
i += 1
# Put the possible remaining right part into the sorted array.
while j <= r:
sorted[k] = nums[j]
k += 1
j += 1
nums[l:l + len(sorted)] = sorted
m = (l + r) // 2
self._mergeSort(nums, l, m)
self._mergeSort(nums, m + 1, r)
merge(nums, l, m, r)
# code by PROGIEZ
Additional Resources
- Explore all LeetCode problem solutions at Progiez here
- Explore all problems on LeetCode website here
Happy Coding! Keep following PROGIEZ for more updates and solutions.