可以看出中间位置两段起码有一个是有序的(不是左边,就是右边),那么就可以在有序的范围内使用二分查找;如果不再有序范围内,就到另一半去找。
参考代码
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移动开发全套学习资料》送给大家,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频
如果你觉得这些内容对你有帮助,可以添加下面V无偿领取!(备注Android)
最后
针对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进阶实践技术,群内还有技术大牛一起讨论交流解决问题。