码迷,mamicode.com
首页 > 编程语言 > 详细

Java 实现二分查找\折半查找

时间:2014-09-12 17:17:23      阅读:179      评论:0      收藏:0      [点我收藏+]

标签:二分查找   数据结构   折半查找   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;

    }

}

 

Java 实现二分查找\折半查找

标签:二分查找   数据结构   折半查找   java实现二分查找   

原文地址:http://blog.csdn.net/woody891/article/details/39230825

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!