折半查找法查找字母C语言,C程序折半查找法

#include

#include

//子函数

int binary_search(int arr[],int k,int left,int right)

{

while(left<=right)//建立一个循坏

{

int mid=left+(right-left)/2;//下标中间值

if(arr[mid]>k)

{

right=mid-1;

}

else if(arr[mid]

left=mid+1;

else

{

return mid;//走到这就是等于。K就是要找的 ,返回的是下标值

}

}

return -1;//这里即left>right .找不到这个数

}

int main()//主函数

{

int arr[]={1,2,3,4,5,6,7,8,9,10};

int left=0;

int right=sizeof(arr)/sizeof(arr[0])-1;//这个公式只能在arr定义下面用,哪里定义哪里用

int m=7;

int binary_search(arr,m,left,right); //不能传值7.可以传常量m=7,

int ret=binary_search(arr,m,left,right);//????函数声明 函数中包含数组,目标值,范围左下标。范围右下标 ret是返回值,

if(-1==ret)//ret作为返回值。返回-1即找不到

printf("找不到啦\n");

else

printf("找到啦\n");//ret是函数的返回值,要么-1.找不到、要么下标值mid,即对应要找的值。找到啦

return 0;

}

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值