首页 > 其他 > 详细

java二分查找法

时间:2014-02-25 19:23:02      阅读:246      评论:0      收藏:0      [点我收藏+]
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
public class JdbcTest {
    public static void main(String[] args){
        int[] arr = {1,2,3,4,5,6,7,8};
        int result = searchHalf_2(arr, 5);
        System.out.println(result);
    }
    /**
     * 二分查找法(要求待查表为有序表)
     * @param arr 数组
     * @param key 要查找的数
     * @return 返回查找的数在数组中的索引位置
     */
    public static int searchHalf_2(int[] arr, int key){
        int min = 0;
        int max = arr.length - 1;
        int mid = (min + max)/2;
        while(key != arr[mid]){
            if(key > arr[mid]){
                min = mid + 1;
            }else{
                max = mid - 1;
            }
            if(min > max){
                return -1;
            }
            mid = (min + max)/2;
        }
        return mid;
    }
}

  

java二分查找法

原文:http://www.cnblogs.com/lxricecream/p/3565865.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!