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 數(shù)組
     * @param temp 要查找的數(shù)字
     * @return 返回改數(shù)字在數(shù)組中的下標位置,-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;
    }
}

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容