当前位置: 首页 > wzjs >正文

学做网站论坛会员账户免费加速器

学做网站论坛会员账户,免费加速器,自建网站做外贸好做吗,程序员必知的网站题目: 给定两个大小分别为m和n的正序(从小到大)数组nums1和nums2。请找出并返回这两个正序数组的中位数。 通过双指针和二分查找的思想,找到两个有序数组的中位数。 1.初始化和基本情况处理 首先获取两个个数组的长度m和n,计算…

题目:

给定两个大小分别为m和n的正序(从小到大)数组nums1和nums2。请找出并返回这两个正序数组的中位数。


通过双指针和二分查找的思想,找到两个有序数组的中位数。

1.初始化和基本情况处理

首先获取两个个数组的长度m和n,计算总长度total=m+n

定义一个辅助函数,用于找到两个数组合并后的第k小的元素

2.寻找第k小的元素

使用双指针i和j分别遍历nums[i]和nums[j]

边界条件处理:

如果i到达nums1的末尾,返回nums2中从j开始的第k个元素

如果j到达nums2的末尾,则返回nums1中从i开始的第k个元素。

如果k==1,则返回nums[i]和nums[j]中较小的值

二分查找:

计算mid=k//2,并确定两个数组中的比较位置new_i和new_j

比较nums1[new_i]和nums2[new_j],如果nums1[new_i]<=nums2[new_j],说明nums1的前mid个元素可以排除,他们不可能是第k小的元素,因此更新,i和j

否则,排除nums2的前mid个元素,更新j和k

3.计算中位数

奇数长度:如果total是奇数,直接返回第total+1//2小的元素

偶数长度:如果total是偶数,就返回第total//2和total.//2+1的平均值

class Solution(object):def findMedianSortedArrays(self, nums1, nums2):""":type nums1: List[int]:type nums2: List[int]:rtype: float"""m,n=len(nums1),len(nums2) #计算两个数组的长度total=m+n  #两个数组长度的总和def findKthElement(k): #在两个有序数组中找到第 k 小的元素i,j=0,0  #初始化两个指针i和j,分别用于跟踪nums1和nums2 的当前位置while True:if i==m:return nums2[j+k-1]#如果nums1已经全部被排除i == m,则k小的元素在nums2 中,位置是j + k - 1if j==n:return nums1[i+k-1]#如果nums2已经全部被排除j == n,则 k小的元素在 nums1 中,位置是i + k - 1if k==1:  # k 减到 1,说明要找最小的元素return min(nums1[i],nums2[j])mid=k//2  #当前 k 的一半new_i=min(i+mid-1,m-1)#ew_i 是 nums1 中从当前位置 i 开始,向后移动 mid-1 个位置,但不能超过数组长度new_j=min(j+mid-1,n-1)   #同理if nums1[new_i]<=nums2[new_j]: #nums1的前new_i - i + 1 个元素可以安全排除k-=new_i-i+1  #减去排除的元素数量i=new_i+1else:k-=new_j-j+1 #排除 nums2 的前 new_j - j + 1 个元素j=new_j+1if total%2==1: #合并后数组长度是奇数,直接返回中间的那个元素(第 (total+1)/2 小的元素)return findKthElement((total+1)//2)else:  #合并后数组长度是偶数,返回中间两个元素的平均值left=findKthElement(total//2)right=findKthElement(total//2+1)return (left+right)/2.0

时间复杂度:O(log(min,m,n))).每次k会减半

空间复杂度:O(1)


文章转载自:

http://YmFq42n0.qrzqd.cn
http://3eZ8U73k.qrzqd.cn
http://T0Fpot9b.qrzqd.cn
http://z2u4h3Cn.qrzqd.cn
http://KsKIdLFJ.qrzqd.cn
http://nRNiyRBN.qrzqd.cn
http://isFFoxfj.qrzqd.cn
http://k3tKGPwf.qrzqd.cn
http://RcuZk7th.qrzqd.cn
http://EYOMe0nb.qrzqd.cn
http://xYOnyNwm.qrzqd.cn
http://WZXCu1g0.qrzqd.cn
http://Mx0cNBsT.qrzqd.cn
http://jaw5zrhq.qrzqd.cn
http://GUXmNueF.qrzqd.cn
http://V8KX4OF9.qrzqd.cn
http://M5Ci7ol9.qrzqd.cn
http://gZzkDA8t.qrzqd.cn
http://bdQOdCoe.qrzqd.cn
http://ZcxEtrHD.qrzqd.cn
http://7dVS5Oc7.qrzqd.cn
http://stmTQe7e.qrzqd.cn
http://VoP45CiN.qrzqd.cn
http://aj8lODiL.qrzqd.cn
http://fgvA6Via.qrzqd.cn
http://ydIEUMWy.qrzqd.cn
http://KQGajYwM.qrzqd.cn
http://YiAPHVnm.qrzqd.cn
http://nYlUtiCH.qrzqd.cn
http://Zqx6L8Fq.qrzqd.cn
http://www.dtcms.com/wzjs/697322.html

相关文章:

  • 一个网站是如何知道是谁来访问上海h5网站建设
  • 开家网站建设培训学校小程序开发平台哪个产品好
  • 行业门户网站建设费用宝安网站制作
  • 简单的cms建站系统python培训班
  • 建设 网站工作汇报做网站的一般多钱
  • 管理网站制作wordpress国内主题排行
  • 网站建设一般多少钱新闻网站建设预付款
  • 电商网站建设培训学校小说网站排名
  • 网站建设费一般多少钱给我免费播放电影
  • 什么做网站赚钱搜索引擎营销就是seo
  • 怎么看网站做的外链php微信公众号开发教程
  • wordpress做分类网站建设局和住建局的区别
  • 网站建设主要推广方式张家港早晨网站制作
  • 图书馆第一代网站建设专业网站托管的公司
  • 仿站违法吗门店设计装修效果图
  • 网站基本信息设置什么叫做响应式网站
  • 深圳公司开发网站网站建设与开发
  • 网站图片如何做缓存做i爱小说网站
  • 北京 网站建设目前免费的h5制作软件
  • 网站开发的套路百度网站的结构
  • 吴江区建设工程招标网站360收录提交入口网址
  • 沈阳网站建设制作wordpress 评论群发
  • 单位门户网站建设方案江苏省建设工程招标网官网
  • 前端网站建设深圳大浪有做网站的吗
  • 黄石网站设计公司西电信息化建设处网站
  • 购物网站设计理念熟悉网页设计人机交互实验报告
  • 电子商务网站建设域名做网站便宜还是app便宜
  • 宁津做网站免费ppt模板下载不用钱的
  • 漳州公司做网站做网站优化最快的方式
  • 如何让网站排名下降win7云主机怎么做网站