2个有序数组第K大 logK解法

该博客探讨了如何使用分治策略在两个有序数组中找到第K大元素的问题。通过每次减少K/2,可以逐步缩小查找范围。在边界条件下,根据数组元素的比较结果决定排除哪个数组的元素。这种方法同样适用于寻找有序数组的中位数。对于偶数个元素,需要进行两次查找并取平均,而对于奇数个元素,直接找到中间位置即可。
摘要由CSDN通过智能技术生成

findKth中
每次减少K/2,第一次找第5大的,那么第二次找第三大的
先考虑边界条件

rm1 rm2分别表示从第一个第二个数组开始排除的位置
初始化为K/2

if nums1[rm1-1] < nums2[rm2-1]
这个表示可以排除 rm1个数了,如果正常就是排除了K/2个数
进入下一次递归

用这个可以解决2个有序数组的中位数,分情况讨论一下,如果是偶数个,那么找2次,再求平均。如果是奇数个那么直接求中间的 第 len1+len2 / 2 +1 个



//两个有序数组第k小的数
func findkth(nums1 []int, nums2 []int, k int) int {
   
	if len(nums1) == 0 {
   
		return nums2[k-1]
	}
	if len(nums2) == 0 {
   </
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值