088-merge-sorted-array
Question
https://leetcode.com/problems/merge-sorted-array/description/
Given two sorted integer arrays nums1 and nums2, merge nums2 into nums1 as one sorted array.
Note:
You may assume that nums1 has enough space (size that is greater or equal to m + n) to hold additional elements from nums2. The number of elements initialized in nums1 and nums2 are m and n respectively.
Example:
Thought Process
- Since array nums1 has enough space, we can put the the element directly into nums1
- We can either start from beginning or the end
- Starting from the end is better because we don't have tor swift the element
- We can use two pointers to track the last index we fill while comparing these two arrays
- Time complexity O(n)
- Space complexity O(1)
Solution
class Solution {
public void merge(int[] nums1, int m, int[] nums2, int n) {
int len = m + n;
while (n > 0) {
if (m > 0 && nums1[m - 1] > nums2[n - 1]) nums1[--len] = nums1[--m];
else nums1[--len] = nums2[--n];
}
}
}