溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

Java binarysearch方法原理詳解

發(fā)布時(shí)間:2020-08-27 22:45:28 來源:腳本之家 閱讀:331 作者:dyhaohaoxuexi 欄目:編程語言

這篇文章主要介紹了Java binarysearch方法原理詳解,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下

首先 數(shù)組排序需要import java.util.Arrays類

binarysearch有兩個(gè)用法,一個(gè)是在整個(gè)數(shù)組里搜索,一個(gè)是在指定范圍搜索,其實(shí)都是差不多的,可以將前者視為后者的特殊情況。

用法1

binarySearch(Object[], Object key)

Object是目標(biāo)數(shù)組,key是目標(biāo)值,要求目標(biāo)數(shù)組必須要經(jīng)過排序的,否則無法找到正確的結(jié)果

查詢無非就是兩種結(jié)果,一種是目標(biāo)值在目標(biāo)數(shù)組里,另一種是不在

所以返回值也分為正負(fù)兩種,目標(biāo)值在目標(biāo)數(shù)組內(nèi)的,返回下標(biāo)(如果有多個(gè)相同的,無法確定找到的是哪個(gè),因?yàn)槭嵌炙阉鳎?/p>

目標(biāo)值不在數(shù)組內(nèi)的,返回 -(第一個(gè)大于目標(biāo)值的元素的下標(biāo)+1),類似的,如果數(shù)組內(nèi)的值都比目標(biāo)值小,則是返回-(數(shù)組長度+1)

樣例:

import java.util.Arrays;
public class number {
  public static void main(String[] args) {
  int a[] = new int[] {1, 3, 4, 6, 8, 9}; 
  int x1 = Arrays.binarySearch(a, 5); 
  int x2 = Arrays.binarySearch(a, 4); 
  int x3 = Arrays.binarySearch(a, 0); 
  int x4 = Arrays.binarySearch(a, 10);
  System.out.println(x1+" "+x2+" "+x3+" "+x4);
  }      
}

輸出:

-4 2 -1 -7

也可以這么理解:

Java binarysearch方法原理詳解

對(duì)應(yīng)相應(yīng)的位置輸出即可。

用法2

binarySearch(Object[], int fromIndex, int toIndex, Object key)

加了兩個(gè)int變量,代表區(qū)間的開始和結(jié)束,從fromindex(包含)到toindex(不包含)這個(gè)區(qū)間里面搜索,返回值和前面用法1類似,唯一有所不同的是,當(dāng)如果區(qū)內(nèi)的值都比目標(biāo)值小,則是返回-(toindex+1),如果區(qū)間內(nèi)的值都比目標(biāo)值大,則返回-(fromindex+1),仔細(xì)想想不難理解,用法1就相當(dāng)于fromindex為0且toindex為數(shù)組長度的用法2。

以上就是本文的全部內(nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持億速云。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請(qǐng)聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI