有序数组 与二分查找算法的理解
- 有序数组是指数组里的数是按照规定次序排序的,
- 虽然仍然是一些书,但是排列次序不同,看作是不同的数组
- 同时有序数组的优点会比无序数组快得多
- 但是不好的方面是在插入操作中由于所有靠后的数据都需要移动以腾开空间,所以速度比较慢
- 有序数组和无序数组中的删除操作都很慢,这是因为数据项必须向前移动来填补已删除数据项的洞
- 有序数组在查找频繁的情况下十分有用,但是若插入与删除较为频繁时,则无法高效的工作
- 二分查找的条件是对有序的数组进行排序,
- 二分查找需要的时间与数组中数据项的个数成正比
- 循环中的每一步将范围缩小一半,最终这个范围会小到无法再分割
二分查找算法的思路
- 一个有序数组,想查找一个数字key的下标,首先算出中间的下边mid,利用min把这个数组分成两半,前一半是0到mid-1,后一半从mid+1到数组最后的一个元素(下标是数组长度-1)。首先是把查找的元素和中间的元素mid比较,然后判断这个元素是大于还是小于,大于的话就走后一半(也就是mid+1到数组的最后一个元素 数组长度-1),反之小于就走前面的一半(0到mid-1),这样反复去中间取中间比较最后就会定位要获取到的元素的下标。
二分查找有两种实现方式
非递归方式实现
int[] arr = {
1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13};
int low = 0;
int high = arr.length-1;
int i =