LeetCode 004 两个排序数组的中位数

Hello World

问题

给定两个大小为 mn 的有序数组 nums1nums2

请找出这两个有序数组的中位数。

示例1:

1
2
3
4
nums1 = [1, 3]
nums2 = [2]
中位数是 2.0

示例2:

1
2
3
4
nums1 = [1, 2]
nums2 = [3, 4]
中位数是 (2 + 3)/2 = 2.5

解答

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
class Solution {
public double findMedianSortedArrays(int[] nums1, int[] nums2) {
int m = nums1.length;
int n = nums2.length;
int[] output = new int[m+n];
int i = 0, j = 0, k = 0;
while(i < m && j < n) {
if(nums1[i] < nums2[j]) {
output[k++] = nums1[i++];
} else {
output[k++] = nums2[j++];
}
}
while(i < m) {
output[k++] = nums1[i++];
}
while(j < n) {
output[k++] = nums2[j++];
}
double result = 0.0;
if((m + n) % 2 == 0) {
int a = output[(m + n) / 2];
int b = output[(m + n) / 2 - 1];
result = (a + b) / 2.0;
}
if((m + n) % 2 == 1) {
result = output[(m + n) / 2];
}
return result;
}
}
------------- 本 文 结 束 感 谢 您 的 阅 读 -------------
坚持原创技术分享,您的支持将鼓励我继续创作!
0%