C语言中的二分查找简述

本文简述了C语言中的二分查找算法,强调该算法适用于有序数组。通过比较目标值与数组中间元素,不断缩小查找范围,最终找到目标元素或确定其不存在。并提供了在整型有序数组中应用二分查找的示例代码,查找成功返回下标,失败则返回 -1。
摘要由CSDN通过智能技术生成

C语言中的二分查找简述

1.二分查找只能对于有序数组,在有序数组中如果要找的对象大于这个有序数组的中间元素,就应该把查找的范围移动到后半段,如果要找的对象小于找个有序数组的中间元素,就应该把范围移动到左边,依次移动范围即可找到要查找的元素

例如:2.写代码可以在整型有序数组中查找想要的数字,找到了返回下标,找不到返回 - 1.(折半查找)

include <stdio.h>
include <stdlib.h>
int mystr(int arr[20],int len,int a) {//查找元素的函数,形参为数组和数组长度和待查找元素
	int i = 0;
	int L = 0;//左边元素的下标
	int R = len-1;//右边元素的下标
	while (L <= R) {//如果左边下标小于等于右边下标就进入循环
		if (arr[(L + R) / 2] > a) {//对比待查找元素和数组中间元素
			R = (L + R) / 2 - 1;//右边的下标应该移动到中间元素的左边一位
		}
		else if (arr[(L + R) / 2] < a) {
			L = (L + R) / 2 + 1;//同理左边下标应该移动到中间元素右边一位
		}
		else if (arr[(L + R) / 2] == a) {
			return (L + R) / 2;//找到以后返回数组的下标
		}
		else {
			return -1;
		}

	}
	return -1;
}
int main() {
	int arr[] = { 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11 };
	int len = sizeof(arr) / sizeof(arr[0]);//求出数组长度
	int ret = mystr(arr, len,6);//输入数组,长度,待查找为6
	printf("%d\n", ret);打印出函数返回的结果
	system("pause");
	return 0;
}

输出结果:
在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值