C语言二分查找的区间问题

概念

什么是二分查找呢?
二分查找:在有序数组中查找某一特定元素的搜索算法。

二分查找又称折半查找,通过将数组折半,用中间值和查找值作比较,多次使用,直到找到要查找的值。
注意:二分查找的前提是,数组必须是要有序的。

二分查找

c 复制代码
int main()
{
	int arr[5] = { 1,2,3,4,5 };
	int begin = 0;
	int end = 4;
	int x = 2;
	int mid = 0;
	while (begin <= end)
	{
		mid = begin + ((end - begin) >> 1);
		if (arr[mid] > x)
			end = mid - 1;
		else if (arr[mid] < x)
			begin = mid + 1;
		else
			break;
	}
	printf("下标是%d\n", mid);
	return 0;
}


区间问题

1.需要注意的是,以上的代码是用的闭区间,保持左闭右开的区间,即(begin=0,end=4)但是还有一种是左闭右开的区间(begin=0,end=5)

那么我们接下来讲一讲左闭右开的区间

c 复制代码
int main()
{
	int arr[5] = { 1,2,3,4,5 };
	int begin = 0;
	int end = 5;
	int x = 2;
	int mid = 0;
	while (begin < end)//这里是小于,不是小于等于
	{
		mid = begin + ((end - begin) >> 1);
		if (arr[mid] > x)
			end = mid;//这里不会减一了
		else if (arr[mid] < x)
			begin = mid + 1;
		else
			break;
	}
	printf("下标是%d\n", mid);
	return 0;
}

代码的不同,我已经标注出来了

如果我们继续使用end=mid-1的话,看一看会有什么效果。

因此,我们在使用二分查找的时候,需要注意它的区间和循环条件。

相关推荐
zhangyao9403301 小时前
关于js导入Excel时,Excel的(年/月/日)日期是五位数字的问题。以及对Excel日期存在的错误的分析和处理。
开发语言·javascript·excel
骑驴看星星a2 小时前
【Three.js--manual script】4.光照
android·开发语言·javascript
2301_795167203 小时前
玩转Rust高级应用 如何避免对空指针做“解引用”操作,在C/C++ 里面就是未定义行为
c语言·c++·rust
星释3 小时前
Rust 练习册 :Leap与日期计算
开发语言·后端·rust
智驱力人工智能4 小时前
基于视觉分析的人脸联动使用手机检测系统 智能安全管理新突破 人脸与手机行为联动检测 多模态融合人脸与手机行为分析模型
算法·安全·目标检测·计算机视觉·智能手机·视觉检测·边缘计算
悟能不能悟5 小时前
java的java.sql.Date和java.util.Date的区别,应该怎么使用
java·开发语言
2301_764441335 小时前
水星热演化核幔耦合数值模拟
python·算法·数学建模
循环过三天5 小时前
3.4、Python-集合
开发语言·笔记·python·学习·算法
_院长大人_6 小时前
设计模式-工厂模式
java·开发语言·设计模式
MATLAB代码顾问6 小时前
MATLAB实现决策树数值预测
开发语言·决策树·matlab