二分查找的相关算法题,Spring都没弄明白凭什么拿高薪

文章介绍了在存在重复元素的情况下如何扩展二分查找算法,并提供了一个处理排序数组中数字出现次数的方法。同时,作者分享了针对Android开发者的全套学习资料,涵盖高级UI、性能优化等内容。
摘要由CSDN通过智能技术生成

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

可以看出中间位置两段起码有一个是有序的(不是左边,就是右边),那么就可以在有序的范围内使用二分查找;如果不再有序范围内,就到另一半去找。

参考代码

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

int search(int A[], int n, int target) {

int beg = 0;

int end = n - 1;

while (beg <= end)

{

int mid = beg + (end - beg) / 2;

if(A[mid] == target)

return mid;

if(A[beg] <= A[mid])

{

if(A[beg] <= target && target < A[mid])

end = mid - 1;

else

beg = mid + 1;

}

else

{

if(A[mid] < target && target <= A[end])

beg = mid + 1;

else

end = mid - 1;

}

}

return -1;

}

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

扩展

上边的有求是没有重复的元素,现在稍微扩展下,可以有重复的元素,其他的要求不变。

思路

大致思路与原来相同,这是需要比较A[beg] 与 A[mid]的关系

  • A[beg]  < A[mid] ————左边有序

  • A[beg]  > A[mid] ————右边有序

  • A[beg]  = A[mid] ————++beg

boolean search(int A[], int n, int target) {

int beg = 0;

int end = n - 1;

while (beg <= end)

{

int mid = beg + (end - beg) / 2;

if(A[mid] == target)

return true;

if(A[beg] < A[mid])

{

if(A[beg] <= target && target < A[mid])

end = mid - 1;

else

beg = mid + 1;

}

else 0if(A[beg] > A[mid])

{

if(A[mid] < target && target <= A[end])

beg = mid + 1;

else

end = mid - 1;

}

else

++beg;

}

return false;

}

3 数字在排序数组中的出现次数

//二分查找,二分查找key第一次出现的位置,二分查找最后一次出现的key

//返回两者相减+1或者找到第一次出现的位置,向后查找

int binarySearchFirstPos(int * iArr, int l, int h, int key)

{

while(l <= h )

{

int mid = (l + h) / 2;

if(iArr[mid] < key)

l = mid +1;

elseif(iArr[mid] > key)

h = mid - 1;

else

{

if(mid == l || iArr[mid - 1] != key)

return mid;

else

h = mid - 1;

}

}

return -1;

}

int binarySearchLastPos(int * iArr, int l, int h, int key)

{

while(l <= h)

{

int mid = (l + h) / 2;

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数初中级安卓工程师,想要提升技能,往往是自己摸索成长,但自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年最新Android移动开发全套学习资料》送给大家,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
img
img
img
img

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频
如果你觉得这些内容对你有帮助,可以添加下面V无偿领取!(备注Android)
img

最后

针对Android程序员,我这边给大家整理了一些资料,包括不限于高级UI、性能优化、架构师课程、NDK、混合式开发(ReactNative+Weex)微信小程序、Flutter等全方面的Android进阶实践技术;希望能帮助到大家,也节省大家在网上搜索资料的时间来学习,也可以分享动态给身边好友一起学习!

  • Android前沿技术大纲

  • 全套体系化高级架构视频

资料领取:点赞+点击GitHub免费获取

往期Android高级架构资料、源码、笔记、视频。高级UI、性能优化、架构师课程、混合式开发(ReactNative+Weex)全方面的Android进阶实践技术,群内还有技术大牛一起讨论交流解决问题。

态给身边好友一起学习!

  • Android前沿技术大纲

    [外链图片转存中…(img-NfYYpxeg-1710891688859)]

  • 全套体系化高级架构视频

    [外链图片转存中…(img-BaqE9XEy-1710891688860)]

资料领取:点赞+点击GitHub免费获取

往期Android高级架构资料、源码、笔记、视频。高级UI、性能优化、架构师课程、混合式开发(ReactNative+Weex)全方面的Android进阶实践技术,群内还有技术大牛一起讨论交流解决问题。

  • 21
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值