码迷,mamicode.com
首页 > 其他好文 > 详细

4. Median of Two Sorted Arrays

时间:2018-10-16 17:36:08      阅读:176      评论:0      收藏:0      [点我收藏+]

标签:sort   amp   ted   本质   hal   wing   cto   均值   stat   

 1 static int wing=[]()
 2 {
 3     std::ios::sync_with_stdio(false);
 4     cin.tie(NULL);
 5     return 0;
 6 }();
 7 
 8 class Solution 
 9 {
10 public:
11     double findMedianSortedArrays(vector<int>& A, vector<int>& B) 
12     {
13         int m=A.size(),n=B.size();
14         if(m>n)
15         {
16             swap(A,B);
17             swap(m,n);
18         }
19         if(n==0)
20             return -1.0;
21         int imin=0,imax=m,half_len=(m+n+1)/2;
22         while(imin<=imax)
23         {
24             int i=(imin+imax)/2;
25             int j=half_len-i;
26             if(i<m&&B[j-1]>A[i])
27                 imin=i+1;
28             else if(i>0&&A[i-1]>B[j])
29                 imax=i-1;
30             else
31             {
32                 int max_of_left=0;
33                 if(i==0)
34                     max_of_left=B[j-1];
35                 else if(j==0)
36                     max_of_left=A[i-1];
37                 else
38                     max_of_left=max(A[i-1],B[j-1]);
39                 
40                 if((m+n)%2==1)
41                     return max_of_left;
42                 
43                 int min_of_right=0;
44                 if(i==m)
45                     min_of_right=B[j];
46                 else if(j==n)
47                     min_of_right=A[i];
48                 else
49                     min_of_right=min(A[i],B[j]);
50                 return (max_of_left+min_of_right)/2.0;
51             }
52         }
53     }
54 };

本质就是对较短数组进行二分查找,找到一个下标 i ,使得 i 和其对应的较长数组中的 j 满足以下条件:

1、i + j = (m + n + 1 )/ 2

2、左侧最大元素小于右侧最小元素

此时,若全部元素数量为奇数,则左侧最大元素为中位数

若全部元素数量为偶数,则左侧最大和右侧最小的均值为中位数

4. Median of Two Sorted Arrays

标签:sort   amp   ted   本质   hal   wing   cto   均值   stat   

原文地址:https://www.cnblogs.com/zhuangbijingdeboke/p/9798660.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!