-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy path88-merge-sorted-array.cpp
32 lines (29 loc) · 1.34 KB
/
88-merge-sorted-array.cpp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
// Title: Merge Sorted Array
// Description:
// You are given two integer arrays nums1 and nums2, sorted in non-decreasing order,
// and two integers m and n, representing the number of elements in nums1 and nums2 respectively.
// Merge nums1 and nums2 into a single array sorted in non-decreasing order.
// The final sorted array should not be returned by the function, but instead be stored inside the array nums1.
// To accommodate this, nums1 has a length of m + n, where the first m elements denote the elements that should be merged,
// and the last n elements are set to 0 and should be ignored. nums2 has a length of n.
// Link: https://leetcode.com/problems/merge-sorted-array/
// Time complexity: O(m+n)
// Space complexity: O(1)
class Solution {
public:
void merge(vector<int>& nums1, int m, vector<int>& nums2, int n) {
int i1 = m - 1;
int i2 = n - 1;
int j = m + n - 1;
while (i1 >= 0 && i2 >= 0) {
// pick the greater element and move it to the back of nums1
if (nums1[i1] > nums2[i2]) {
nums1[j--] = nums1[i1--];
} else {
nums1[j--] = nums2[i2--];
}
}
// move the remaining elements (no need to move elements already in nums1)
while (i2 >= 0) nums1[j--] = nums2[i2--];
}
};