C语言中的二分查找的实现及其问题

一,原理

不会查找数列的全部元素,而查找的数据量其实正好符合元素的对数,正常情况下每次查找的元素都在一半一半地减少。 所以二分查找的 时间复杂度 为 O (log 2 n)。

二,适用条件

二分查找要求数列本身有序,所以在选择的时候需要确认数列是否本身有序,如果无序,则还需要进行排序,

三,实现思路

  1. 初始状态下,将整个序列作为搜索区域(假设为 [left , right]);

  2. 找到搜索区域内的中间元素(假设所在位置为 a[mid]),和目标元素进行比对。 如果相等,则搜索成功;如果中间元素大于目标元素,表明目标元素位于中间元素的左侧,将 [left , right-1] 作为新的搜素区域;反之,若中间元素小于目标元素,表明目标元素位于中间元素的右侧,将 [left + 1 , right] 作为新的搜素区域;

  3. 重复执行第二步,直至找到目标元素。 如果搜索区域无法再缩小,且区域内不包含任何元素,表明整个序列中没有目标元素,查找失败。

四,代码的实现

 

 

 

截的长图:

 

五,问题

1,把sz放到函数里面求会怎样

 

 

原因

在main函数中,int ret = binary_search(arr, key) 这里的arr传参,实际传递的不是数组本身,而是数组首元素的地址,所以在binary_search函数中sz算出来应该是1,所以出错了。

传入地址,其实应该写成指针int binary_search(int* a , int k) 。所以那里的int a[] 本质上就应该是指针,指针求不出元素个数。

所以不能把元素个数放到里面求。

注意:如果函数内部需要参数部分传入一个元素数组的个数,一定是在外面求好元素的个数,作为参数传入进去。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值