The original problem can be found on LeetCode at: Median of Two Sorted Arrays and difficulty level is difficult.
Don’t be fooled by the difficulty level. After reading this article, you can do it, too.
At first glance, finding the median of a two-incrementing array is not too difficult because the sequences are ordered, so it is easy to think of a time order O(m + n) : take the smaller element in each array and find the middle element.
But this is not optimal, we can also implement the time complexity of O(log(m + n)) algorithm, naturally we can think of binary search method to solve.
They’re asking us to find the median of two arrays, and we can generalize to find the KTH largest element in both arrays, so finding the median is just a special case of that. The helper function is used to find the KTH largest element in two arrays. Here’s how it works:
If we want to search for the KTH largest number, let’s say we want to find the first m elements from array A and the first k-m elements from array B. Since arrays A and B are sorted separately, A[m-1] is greater than all the other elements taken from array A, and B[k-m-1] is greater than all the other elements taken from array B. At this point, although the relative size relationship between the extracted elements is uncertain, the larger of A[m-1] and B[k-m-1] must be the largest of the K elements. Then, the smaller element must not be the KTH largest, which is left to the reader’s imagination.
For the sake of statement, assuming that A[m-1] is the smaller element, then we can write A[0], A[1]… A[m-1] is excluded, and the value of k is updated to k-m, that is, the next time is to find the k-m-largest element from the remaining elements. In this way, we have completed A scope reduction, and the next round of operation is the same.
So when do you stop? There are two cases:
-
When an array is empty, return the last k elements of the other array.
-
When k is equal to 1, you just have to pick one more number, which is the smaller of the two.
In particular, let’s take m = k / 2, and here’s my sketch, just to make sense of it.
Using the above theory, can you write the relevant code?
class Solution {
public double findMedianSortedArrays(int[] nums1, int[] nums2) {
int len = nums1.length + nums2.length;
if (len % 2= =0) {
return (helper(nums1, 0, nums2, 0, len / 2) + helper(nums1, 0, nums2, 0, len / 2 + 1)) / 2.0;
}
return helper(nums1, 0, nums2, 0, (len + 1) / 2);
}
private int helper(int[] nums1, int m, int[] nums2, int n, int k) {
if (m >= nums1.length) return nums2[n + k - 1];
if (n >= nums2.length) return nums1[m + k - 1];
if (k == 1) return Math.min(nums1[m], nums2[n]);
int p1 = m + k / 2 - 1;
int p2 = n + k / 2 - 1;
int mid1 = p1 < nums1.length ? nums1[p1] : Integer.MAX_VALUE;
int mid2 = p2 < nums2.length ? nums2[p2] : Integer.MAX_VALUE;
if (mid1 < mid2) {
return helper(nums1, m + k / 2, nums2, n, k - k / 2);
}
return helper(nums1, m, nums2, n + k / 2, k - k / 2); }}Copy the code
| | Two Sorted Arrays | | |
If you love data structures, algorithms, and LeetCode as much as I do, check out LeetCode on GitHub