2020
12-07
12-07
Java 二分查找的实现及图例解析
二分查找又称折半查找,它是一种效率较高的查找方法。折半查找的算法思想是将数列按有序化(递增或递减)排列,查找过程中采用跳跃式方式查找,即先以有序数列的中点位置为比较对象,如果要找的元素值小于该中点元素,则将待查序列缩小为左半部分,否则为右半部分。通过一次比较,将查找区间缩小一半。折半查找是一种高效的查找方法。它可以明显减少比较次数,提高查找效率。但是,折半查找的先决条件是查找表中的数据元素必须有序...
继续阅读 >
前提:升序数组,待查元素在数组中。二分查找:就是一个递归函数c。待查元素a,当前数组中位数b,如果b=a则返回b的索引,b>a则在b左侧的子数组中调用函数c,否则在b右侧子数组中调用函数c。第一次思考,按着上面的思路编程后的结果:defbinary_search(index,a,value):ifa[(len(a)-1)//2]==value:returnindex+(len(a)-1)//2elifa[(len(a)-1)//2]<value:returnbinary_search(index+(len(a)-...