日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

leetcode--Median of Two Sorted Arrays

發布時間:2025/4/16 编程问答 39 豆豆
生活随笔 收集整理的這篇文章主要介紹了 leetcode--Median of Two Sorted Arrays 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
1.題目描述
There are two sorted arrays A and B of size m and n respectively. Find the median of the two sorted arrays. The overall run time complexity should be O(log (m+n)).
2.解法分析 我本來直接想用二分法求出結果,然后有了下面這個結果,結果發現當m+n為偶數時計算出來的結果不對,因為我最初的算法就是求中位數,而不是題目要求的兩個中位數的平均值。
class Solution { public: vector<int> twoSum(vector<int> &numbers, int target) { // Start typing your C/C++ solution below // DO NOT write int main() function unordered_set<int> myHash; vector<int>::iterator iter; vector<int> result; result.assign(2,0); if(target%2==0) { int count=0; for(int i=0;i<numbers.size();++i) { if(numbers[i]==target/2) { if(count==0){result[0]=i+1;count++; } else { result[1]=i+1;return result; } } } } for(iter=numbers.begin();iter!=numbers.end();++iter) { myHash.insert(*iter); } for(int i=0;i<numbers.size();++i) { myHash.erase(numbers[i]); if(myHash.count(target-numbers[i])==1) { result[0]=i+1;break; } myHash.insert(numbers[i]); } for(int i=result[0];i<numbers.size();++i) { if((numbers[result[0]-1]+numbers[i])==target) { result[1]=i+1;break; } } return result; } };

?

本來想修修補補,看看能不能夠AC,結果弄了好半天煩死了,因此覺得應該會有比較統一的方法。結果搜尋到了一個很統一的方法,這個方法將找兩個數組的中位數推廣到了找兩個數組中第k大的數字,有了這個思路代碼就很簡單了。

class Solution { //more detail refer to: http://fisherlei.blogspot.com/2012/12/leetcode-median-of-two-sorted-arrays.html //using the method of getting the kth number in the two sorted array to solve the median problem //divide-and-conquer //very clean and concise public: double findMedianSortedArrays(int A[], int m, int B[], int n) { if((n+m)%2 ==0) { return (GetMedian(A,m,B,n, (m+n)/2) + GetMedian(A,m,B,n, (m+n)/2+1))/2.0; } else return GetMedian(A,m,B,n, (m+n)/2+1); } int GetMedian(int a[], int n, int b[], int m, int k)//get the kth number in the two sorted array { //assert(a && b); if (n <= 0) return b[k-1]; if (m <= 0) return a[k-1]; if (k <= 1) return min(a[0], b[0]); //a: section1 section2 //b: section3 section4 if (b[m/2] >= a[n/2]) { if ((n/2 + 1 + m/2) >= k) return GetMedian(a, n, b, m/2, k);//abort section 4 else return GetMedian(a + n/2 + 1, n - (n/2 + 1), b, m, k - (n/2 + 1)); //abort section 1 } else { if ((m/2 + 1 + n/2) >= k) return GetMedian( a, n/2,b, m, k);//abort section 2 else return GetMedian( a, n, b + m/2 + 1, m - (m/2 + 1),k - (m/2 + 1));//abort section 3 } } };

轉載于:https://www.cnblogs.com/obama/p/3267037.html

總結

以上是生活随笔為你收集整理的leetcode--Median of Two Sorted Arrays的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: 男人在线天堂 | www夜片内射视频日韩精品成人 | 中文字幕久久网 | 免费无遮挡无码永久视频 | 国产在线观看无码免费视频 | 森林影视官网在线观看 | 日批免费看 | 激情婷婷综合网 | 黑帮大佬和我的三百六十五天 | 男女涩涩网站 | 国产一区二区三区黄 | 综合色亚洲 | 日韩精品久久久久久久酒店 | 久久免费高清 | 理伦毛片 | 亚洲乱妇 | 四虎成人影视 | 人人妻人人澡人人爽人人欧美一区 | 亚洲精品乱码久久久久99 | 欧美亚洲精品在线观看 | 男人的天堂久久 | 蜜桃视频在线观看污 | 免费看aaaaa级少淫片 | 欧美视频免费看欧美视频 | 毛片免费在线观看视频 | 成人欧美一区二区三区小说 | 精品国产一区一区二区三亚瑟 | 国产精品xxx在线 | 欧美精品免费一区二区 | 狠狠激情 | 亚洲精品乱码久久久久久黑人 | 国产精品高清无码在线观看 | 国产精品最新 | 一级黄色片免费观看 | 97一级片| 97精品免费视频 | www插插插无码免费视频网站 | 啪啪免费网 | 天天干天天操 | 国产欧美一区二区三区在线看蜜臂 | 亚洲免费色视频 | 日韩美女视频网站 | 日本精品视频在线观看 | 国产内射老熟女aaaa∵ | 无码人妻丰满熟妇区毛片18 | 五十路中出 | 婷综合 | a亚洲天堂 | 老色鬼在线 | 日韩av视屏 | 日韩激情久久 | 美女一区 | 去毛片| 狠狠爱免费视频 | 极品探花在线播放 | 影音先锋久久久久av综合网成人 | 中文字幕第35页 | 免费成人蒂法网站 | 99在线精品视频免费观看20 | 日韩一区二区视频在线播放 | 好色先生视频污 | 日韩在线观看中文字幕 | 91激情网| 碰超在线| 91精品国产高清一区二区三蜜臀 | 91传媒入口 | 91一区二区三区在线 | 亚洲欧美精品在线观看 | 成人国产欧美 | 国产麻豆91 | 扒下小娇妻的内裤打屁股 | 涩涩网站在线观看 | 亚洲视频日韩 | 亚洲成人av一区 | 韩国伦理片免费看 | 国产玖玖视频 | 第一色影院| 大桥未久恸哭の女教师 | 欧美成人精品一区二区综合免费 | 一区二区视频国产 | 丝袜人妻一区 | 男女视频久久 | 鲁啊鲁在线视频 | 羞羞漫画在线播放 | 一区二区三区四区在线观看视频 | 久久综合一本 | www.超碰在线.com | 97人人视频 | 黄色污污视频网站 | www.youjizz.com在线观看 | 精品成人无码久久久久久 | 中文字幕免费在线视频 | 亚洲国产精品无码观看久久 | 日本福利一区二区 | 成人一区二区三区在线观看 | 波多野结衣影院 | 国产无遮挡又黄又爽免费视频 | 国产黄色在线网站 | 欧美日韩国产三区 |