LeetCode 4 尋找兩個有序陣列的中位數

2021-09-13 17:33:41 字數 797 閱讀 1516

給定兩個大小為 m 和 n 的有序陣列 nums1 和 nums2。

請你找出這兩個有序陣列的中位數,並且要求演算法的時間複雜度為 o(log(m + n))。

你可以假設 nums1 和 nums2 不會同時為空。

示例 1:

nums1 = [1, 3]

nums2 = [2]

則中位數是 2.0

示例 2:

nums1 = [1, 2]

nums2 = [3, 4]

則中位數是 (2 + 3)/2 = 2.5

以下給定兩種解決方案:一種是合併兩個有序陣列,使它們成為乙個有序陣列;另一種則是不合併,利用兩個指標分別指向兩個有序陣列的第乙個元素,然後逐個比較大小。

c++**

合併兩個陣列的方法

class solution 

sort(nums1.begin(), nums1.end());

return getmid(nums1);

}double getmid(vectornums)

else

}};

不合併陣列的方法

class solution 

else if(iter2 == nums2.end())

else if(*iter1 > *iter2)

else

}return (nums1.size() + nums2.size())%2? mid2:(mid1 + mid2)/2.0;

}};

LeetCode 4 尋找兩個有序陣列的中位數

給定兩個大小為 m 和 n 的有序陣列 nums1 和 nums2。請你找出這兩個有序陣列的中位數,並且要求演算法的時間複雜度為 o log m n 你可以假設 nums1 和 nums2 不會同時為空。示例 1 nums1 1,3 nums2 2 則中位數是 2.0 示例 2 nums1 1,2 ...

LeetCode 4 尋找兩個有序陣列的中位數

給定兩個大小為 m 和 n 的有序陣列nums1和nums2。請你找出這兩個有序陣列的中位數,並且要求演算法的時間複雜度為 o log m n 你可以假設nums1和nums2不會同時為空。示例 1 nums1 1,3 nums2 2 則中位數是 2.0示例 2 nums1 1,2 nums2 3,...

LeetCode4 尋找兩個有序陣列的中位數

給定兩個大小為 m 和 n 的有序陣列nums1和nums2。請你找出這兩個有序陣列的中位數,並且要求演算法的時間複雜度為 o log m n 你可以假設nums1和nums2不會同時為空。示例 1 nums1 1,3 nums2 2 則中位數是 2.0示例 2 nums1 1,2 nums2 3,...