https://leetcode-cn.com/problems/median-of-two-sorted-arrays/
难度困难4407
给定两个大小分别为 m
和 n
的正序(从小到大)数组 nums1
和 nums2
。请你找出并返回这两个正序数组的 中位数 。
示例 1:
输入:nums1 = [1,3], nums2 = [2] 输出:2.00000 解释:合并数组 = [1,2,3] ,中位数 2
示例 2:
输入:nums1 = [1,2], nums2 = [3,4] 输出:2.50000 解释:合并数组 = [1,2,3,4] ,中位数 (2 + 3) / 2 = 2.5
示例 3:
输入:nums1 = [0,0], nums2 = [0,0] 输出:0.00000
示例 4:
输入:nums1 = [], nums2 = [1] 输出:1.00000
示例 5:
输入:nums1 = [2], nums2 = [] 输出:2.00000
提示:
nums1.length == m
nums2.length == n
0 <= m <= 1000
0 <= n <= 1000
1 <= m + n <= 2000
-106 <= nums1[i], nums2[i] <= 106
进阶:你能设计一个时间复杂度为 O(log (m+n))
的算法解决此问题吗?
通过次数483,627提交次数1,188,624
class Solution {
public double findMedianSortedArrays(int[] nums1, int[] nums2) {
int [] n = new int[nums1.length+nums2.length];
int i=0,j=0,k=0;
while(i<nums1.length && j<nums2.length)
{
if(nums1[i]<=nums2[j])
{
n[k++]= nums1[i++];
}
else n[k++] = nums2[j++];
}
while(i<nums1.length)
{
n[k++]= nums1[i++];
}
while(j<nums2.length)
{
n[k++] = nums2[j++];
}
if((nums1.length+nums2.length)%2==0) return (n[n.length/2]+n[n.length/2-1])/2.0;
else return n[n.length/2];
}
}
class Solution {
public double findMedianSortedArrays(int[] nums1, int[] nums2) {
int [] n = new int[nums1.length+nums2.length];
int i=0,j=0,k=0,x=n.length/2;
while(i<nums1.length && j<nums2.length)
{
if(nums1[i]<=nums2[j])
{
n[k++]= nums1[i++];
}
else n[k++] = nums2[j++];
if(x<k) break;
}
while(i<nums1.length && x>=k)
{
n[k++]= nums1[i++];
}
while(j<nums2.length && x>=k)
{
n[k++] = nums2[j++];
}
if((nums1.length+nums2.length)%2==0) return (n[n.length/2]+n[n.length/2-1])/2.0;
else return n[n.length/2];
}
}
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
文章由极客之音整理,本文链接:https://www.bmabk.com/index.php/post/69189.html