leetcode刷题实录:4
生活随笔
收集整理的這篇文章主要介紹了
leetcode刷题实录:4
小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.
前言
開始刷leetcode,保證平均每天一道題吧,學(xué)學(xué)別人的思路,提高編程技術(shù)。
目錄
文章目錄
- 前言
- 目錄
- 正文
- 問題3:尋找兩個(gè)有序數(shù)組的中位數(shù)
- 舉例
- 分析
正文
繼續(xù)刷題
問題3:尋找兩個(gè)有序數(shù)組的中位數(shù)
給定兩個(gè)大小為 m 和 n 的有序數(shù)組 nums1 和 nums2。
請你找出這兩個(gè)有序數(shù)組的中位數(shù),并且要求算法的時(shí)間復(fù)雜度為 O(log(m + n))。
你可以假設(shè) nums1 和 nums2 不會(huì)同時(shí)為空。
舉例
nums1 = [1,2,3]
nums2 = [2]
則中位數(shù)是 2.0
分析
這個(gè)問題很難,因?yàn)?#xff0c;有時(shí)間要求,因此,不能使用暴力破解方法。
class Solution:def findMedianSortedArrays(self, nums1: List[int], nums2: List[int]):n1 = len(nums1)n2 = len(nums2)if n1 > n2:return self.findMedianSortedArrays(nums2,nums1)k = (n1 + n2 + 1)//2left = 0right = n1while left < right :m1 = left +(right - left)//2m2 = k - m1if nums1[m1] < nums2[m2-1]:left = m1 + 1else:right = m1m1 = leftm2 = k - m1 c1 = max(nums1[m1-1] if m1 > 0 else float("-inf"), nums2[m2-1] if m2 > 0 else float("-inf") )if (n1 + n2) % 2 == 1:return c1c2 = min(nums1[m1] if m1 < n1 else float("inf"), nums2[m2] if m2 <n2 else float("inf"))return (c1 + c2) / 2總結(jié)
以上是生活随笔為你收集整理的leetcode刷题实录:4的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: leetcode刷题实录:3
- 下一篇: HTTP WS 区别