定义:
二分查找也称折半查找(Binary Search),它是一种效率较高的查找方法。但是,折半查找要求线性表必须采用顺序存储结构,而且表中元素按关键字有序排列。它充分利用了元素间的次序关系,采用分治策略,可在最坏的情况下用O(log n)完成搜索任务。
它的基本思想是:(这里假设数组元素呈升序排列)将n个元素分成个数大致相同的两半,取a[n/2]与欲查找的x作比较,如果x=a[n/2]则找到x,算法终止;如 果x<a[n/2],则我们只要在数组a的左半部继续搜索x;如果x>a[n/2],则我们只要在数组a的右 半部继续搜索x。
1.二分查找
给出一个有序数对n(n=11):{1,2,3,6,9,10,11,13,15,16,20};求13的位置。
动画演示:二分查找与遍历查找的效率对比图
(1)朴素算法:枚举每一个数,从小到大的枚举,与数组进行匹配,最后找到x的位置i,输出。
时间复杂度:o(n);
(2) 二分法:因为是有序的,所以可以比较f[i]是否与x相等,比较大小,大的话则说明x的位置比当前i大,反之则小。