[LeetCode] Median of Two Sorted Arrays

简介: This link has a very concise and fast solution based on binary search. Spend some time reading it and make sure you understand it.

This link has a very concise and fast solution based on binary search. Spend some time reading it and make sure you understand it. It is very helpful. 

Since the C++ interface of this problem has been updated, I rewrite the code below.

 1 class Solution {
 2 public:
 3     double findMedianSortedArrays(vector<int>& nums1, vector<int>& nums2) {
 4         int m = nums1.size(), n = nums2.size();
 5         if (m > n) return findMedianSortedArrays(nums2, nums1);
 6         int i, j, imin = 0, imax = m, half = (m + n + 1) / 2;
 7         while (imin <= imax) {
 8             i = (imin & imax) + ((imin ^ imax) >> 1);
 9             j = half - i;
10             if (i > 0 && j < n && nums1[i - 1] > nums2[j]) imax = i - 1;
11             else if (j > 0 && i < m && nums2[j - 1] > nums1[i]) imin = i + 1;
12             else break;
13         }
14         int num1;
15         if (!i) num1 = nums2[j - 1];
16         else if (!j) num1 = nums1[i - 1];
17         else num1 = max(nums1[i - 1], nums2[j - 1]);
18         if ((m + n) & 1) return num1;
19         int num2;
20         if (i == m) num2 = nums2[j];
21         else if (j == n) num2 = nums1[i];
22         else num2 = min(nums1[i], nums2[j]);
23         return (num1 + num2) / 2.0;
24     }
25 };

 

目录
相关文章
|
11月前
|
存储 缓存 算法
LeetCode刷题---Two Sum(一)
LeetCode刷题---Two Sum(一)
|
9月前
Leetcode 4. Median of Two Sorted Arrays
题目描述很简单,就是找到两个有序数组合并后的中位数,要求时间复杂度O(log (m+n))。 如果不要去时间复杂度,很容易就想到了归并排序,归并排序的时间复杂度是O(m+n),空间复杂度也是O(m+n),不满足题目要求,其实我开始也不知道怎么做,后来看了别人的博客才知道有个二分法求两个有序数组中第k大数的方法。
22 0
|
9月前
Leetcode Find Minimum in Rotated Sorted Array 题解
对一个有序数组翻转, 就是随机取前K个数,移动到数组的后面,然后让你找出最小的那个数,注意,K有可能是0,也就是没有翻转。
34 0
|
11月前
|
存储 C++ Python
LeetCode刷题---Add Two Numbers(一)
LeetCode刷题---Add Two Numbers(一)
|
存储 算法 安全
LeetCode - #2 Add Two Numbers
我们社区从本期开始会将顾毅(Netflix 增长黑客,《iOS 面试之道》作者,ACE 职业健身教练。)的 Swift 算法题题解整理为文字版以方便大家学习与阅读。 不积跬步,无以至千里;不积小流,无以成江海,Swift社区 伴你前行。
LeetCode - #2 Add Two Numbers
|
存储 算法 安全
LeetCode - #1 Two Sum
我们社区从本期开始会将顾毅(Netflix 增长黑客,《iOS 面试之道》作者,ACE 职业健身教练。)的 Swift 算法题题解整理为文字版以方便大家学习与阅读。 不积跬步,无以至千里;不积小流,无以成江海,Swift社区 伴你前行。
LeetCode - #1 Two Sum
LeetCode 167 Two Sum II - Input array is sorted(输入已排序数组,求其中两个数的和等于给定的数)
给定一个有序数组和一个目标值 找出数组中两个成员,两者之和为目标值,并顺序输出
74 0
|
算法 Python
LeetCode 108. 将有序数组转换为二叉搜索树 Convert Sorted Array to Binary Search Tree
LeetCode 108. 将有序数组转换为二叉搜索树 Convert Sorted Array to Binary Search Tree
|
算法 测试技术
LeetCode 88. 合并两个有序数组 Merge Sorted Array
LeetCode 88. 合并两个有序数组 Merge Sorted Array
|
13天前
|
Python
【Leetcode刷题Python】剑指 Offer 32 - III. 从上到下打印二叉树 III
本文介绍了两种Python实现方法,用于按照之字形顺序打印二叉树的层次遍历结果,实现了在奇数层正序、偶数层反序打印节点的功能。
27 6