Java实现二分查找

二分查找算法思想非常简单,就是折半查找一个有序序列,直到找到目标数。其主要思想是:
二分查找算法的前置条件是,一个已经排序好的序列,假设这个序列是升序排列的,这样在查找所要查找的元素时,首先与序列中间的元素进行比较,如果大于这个元素,就在当前序列的后半部分继续查找,如果小于这个元素,就在当前序列的前半部分继续查找,直到找到相同的元素,或者所查找的序列范围为空为止.

1.如何查找?
对于数组来说,我们通常用整形存储其下标。如果我们将所有代码实现在mian()函数中,则left的下标为0,right的下标为arr.length/arr[0].length-1.(因为数组的下标是由0开始)而中间数mid = left+(right-left)/2;(考虑溢出)或者mid = left+((right-left)>>1)

2.查找步骤:

1>如果(arr[middle] > searchnumber),那么第二次查找则在左边再进行二分查找,即将right的下标移到middle-1(因为middle如果是目标数searchnumber的话,会直接返回找到了,如果不是,那么将其下标直接移向middle-1的位置,这样会减少查找的次数)的位置。

2>.如果(arr[middle] <searchnumber),那么第二次查找则在右边再进行二分查找,即将left的下标移到middle+1(类似步骤一的想法)

3>除了这两种情况外,则就是(arr[middle] = searchnumber),说明目标数searchnumber找到了。

4>以上三个

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值