Java 实现二分查找\折半查找
2018-07-20 来源:open-open
二分查找又称折半查找,优点是比较次数少,查找速度快;其缺点是要求待查表为有序表,且插入删除困难。因此,折半查找方法适用于不经常变动而查找频繁的有序列表。
该算法要求:
1、 必须采用顺序存储结构。
2、 必须按关键字大小有序排列。
该算法时间复杂度最坏为:O(logn)
注意点有mid、low、high
其Java实现代码如下:
public class BinarySearch { /** * @param args */ public static void main(String[] args) { // TODO Auto-generatedmethod stub int[] src = {1,3,5,7,8,9}; System.out.println(binarySearch(src,3)); } private static int binarySearch(int[] src, int i) { int low=0; int high=src.length-1; System.out.println("low is"+low); System.out.println("high is"+high); while(low<=high){ int mid = (low+high)/2; System.out.println("mid is"+mid); if(src[mid]==i){ return mid; }else if(i<src[mid]){ high=mid-1; }else{ low=mid+1; } } return -1; } }
标签: 代码
版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点!
本站所提供的图片等素材,版权归原作者所有,如需使用,请与原作者联系。
下一篇:jackson工具类
最新资讯
热门推荐