A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

© funny 中级黑马   /  2015-9-7 22:35  /  360 人查看  /  0 人回复  /   0 人收藏 转载请遵从CC协议 禁止商业使用本文

package com.wf.bean;

public class J {

        /**
         * 二分查找
         */
        public static void main(String[] args) {
                int arr[] = { 11, 22, 33, 44, 55, 66, 77 };
                System.out.println(getIndex(arr, 66));
                System.out.println(getsearch(arr, 55));
        }

        public static int getIndex(int arr[], int value) {
                int min = 0;
                int max = arr.length - 1;
                int mid = (min + max) / 2;

                while (arr[mid] != value) {
                        if (arr[mid] < value) {
                                min = mid + 1;
                        } else if (arr[min] > value) {
                                max = mid - 1;
                        }

                        if (arr[min] > arr[max]) {
                                return -1;
                        }
                        mid = (min + max) / 2;
                }
                return mid;
        }

        public static int getsearch(int arr[], int key) {
                int min = 0, max = arr.length - 1;
                while (min <= max) {
                        int mid = (min + max) / 2;
                        if (key > arr[mid]) {
                                min = mid + 1;
                        } else if (key < arr[mid]) {
                                max = mid - 1;
                        } else {
                                return mid;
                        }
                }
                return -1;
        }
}

0 个回复

您需要登录后才可以回帖 登录 | 加入黑马