之前一直学得不明不白,似懂非懂,如今算是懂了大概。
首先了解二分查找的定义,使用原因,使用要求和目标有助于高效掌握这个算法。
什么是二分查找?
二分查找也称折半查找(Binary Search),又分为整数二分和浮点二分
为什么使用二分查找?
效率比线性查找高。
什么时候可以二分查找?
1.必须采用顺序存储结构。 2.必须按关键字大小有序排列。
二分查找查找的是什么?(重要)
在有序区间里找到第一个大于等于目标值的值,
或最后一个大于等于目标值的值
前者寻找左边界(即寻找符合性质的第一个点)
后者寻找右边界(即寻找符合性质的最后一个点)
整型二分模板(注释都有解释)
1.寻找第一个大于等于k的值(左边界点)
int a[44];//为有序数组
int k;//目标值
int bsearch(int l, int r)
{
while(l < r){
//最终一定是l=r=mid
int mid = l + r >> 1;