Java 实现二分查找/折半查找详解编程语言

    二分查找又称折半查找,优点是比较次数少,查找速度快;其缺点是要求待查表为有序表,且插入删除困难。因此,折半查找方法适用于不经常变动而查找频繁的有序列表。

        该算法要求:

        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; 
 
    } 
 
}

原创文章,作者:ItWorker,如若转载,请注明出处:https://blog.ytso.com/10326.html

(0)
上一篇 2021年7月19日
下一篇 2021年7月19日

相关推荐

发表回复

登录后才能评论