java-二分法查找

public class halfSel<T> {
    public static void main(String[] args) {
        int s[] = {0,2,11,12,33,43,98,99};
        System.out.println(cal(s,12));
    }

    /**
     *
     * @param arr 数组
     * @param temp 要查找的数字
     * @return 返回改数字在数组中的下标位置,-1则没有
     */
    public static int  cal(int[] arr, int temp){
      int length =   arr.length;

      int min = 0;
      int max = length-1;

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

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容