华南俳烁实业有限公司

java

當(dāng)前位置:中華考試網(wǎng) >> java >> java教程 >> 文章內(nèi)容

Java數(shù)組使用binarySearch()方法查找指定元素

來源:中華考試網(wǎng)  [2020年11月25日]  【

  查找數(shù)組是指從數(shù)組中查詢指定位置的元素,或者查詢某元素在指定數(shù)組中的位置。使用 Arrays 類的 binarySearch() 方法可以實現(xiàn)數(shù)組的查找,該方法可使用二分搜索法來搜索指定數(shù)組,以獲得指定對象,該方法返回要搜索元素的索引值。

  binarySearch() 方法有多種重載形式來滿足不同類型數(shù)組的查找需要,常用的重載形式有兩種。

  (1) 第 一種形式如下:

  binarySearch(Object[] a,Object key);

  其中,a 表示要搜索的數(shù)組,key 表示要搜索的值。如果 key 包含在數(shù)組中,則返回搜索值的索引;否則返回 -1 或“-插入點”。插入點指搜索鍵將要插入數(shù)組的位置,即第 一個大于此鍵的元素索引。

  在進(jìn)行數(shù)組查詢之前,必須對數(shù)組進(jìn)行排序(可以使用 sort() 方法)。如果沒有對數(shù)組進(jìn)行排序,則結(jié)果是不確定的。如果數(shù)組包含多個帶有指定值的元素,則無法確認(rèn)找到的是哪一個。

  例 1

  聲明 double 類型的 score 數(shù)組,接著調(diào)用 Arrays 類的 sort() 方法對 score 數(shù)組排序,排序后分別查找數(shù)組中值為 100 和 60 的元素,分別將結(jié)果保存到 index1 和 index2 變量中,最后輸出變量的值。代碼如下:

  public static void main(String[] args) {

  double[] score = { 99.5, 100, 98, 97.5, 100, 95, 85.5, 100 };

  Arrays.sort(score);

  int index1 = Arrays.binarySearch(score, 100);

  int index2 = Arrays.binarySearch(score, 60);

  填寫下面表單即可預(yù)約申請免費試聽java課程!害怕學(xué)不會?助教陪讀,隨時解惑!擔(dān)心就業(yè)?一地學(xué)習(xí),可全國推薦就業(yè)!

預(yù)約申請免費聽java課程

  • 地區(qū):
  • 姓名:
  • 手機:

  System.out.println("查找到 100 的位置是:" + index1);

  System.out.println("查找到 60 的位置是:" + index2);

  }

  執(zhí)行上述代碼,輸出結(jié)果如下:

  查找到 100 的位置是:5

  查找到 60 的位置是:-1

  (2) 除了上述形式外,binarySearch() 還有另一種常用的形式,這種形式用于在指定的范圍內(nèi)查找某一元素。語法如下:

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

  其中,a 表示要進(jìn)行查找的數(shù)組,fromIndex 指定范圍的開始處索引(包含開始處),toIndex 指定范圍的結(jié)束處索引(不包含結(jié)束處),key 表示要搜索的元素。

  在使用 binarySearch() 方法的上述重載形式時,也需要對數(shù)組進(jìn)行排序,以便獲取準(zhǔn)確的索引值。如果要查找的元素 key 在指定的范圍內(nèi),則返回搜索鍵的索引;否則返回 -1 或 “-插入點”。插入點指要將鍵插入數(shù)組的位置,即范圍內(nèi)第 一個大于此鍵的元素索引。

  例 2

  對例 1 中創(chuàng)建的 score 數(shù)組進(jìn)行查找元素,指定開始位置為 2,結(jié)束位置為 6。代碼如下:

  public static void main(String[] args) {

  double[] score = {99.5,100,98,97.5,100,95,85.5,100};

  Arrays.sort(score);

  int index1 = Arrays.binarySearch(score,2,6,100);

  int index2 = Arrays.binarySearch(score,2,6,60);

  System.out.println("查找到 100 的位置是:"+index1);

  System.out.println("查找到 60 的位置是:"+ index2);

  }

  執(zhí)行上述代碼,輸出結(jié)果如下:

  查找到 100 的位置是:5

  查找到 60 的位置是:-3

責(zé)編:fushihao

上一篇:Java快速排序法(Quicksort)

下一篇: 沒有了

  • 會計考試
  • 建筑工程
  • 職業(yè)資格
  • 醫(yī)藥考試
  • 外語考試
  • 學(xué)歷考試
保康县| 洛阳市| 天镇县| 龙江县| 兴化市| 乐亭县| 滦平县| 平利县| 驻马店市| 青田县| 禄丰县| 嘉荫县| 聂拉木县| 共和县| 阿尔山市| 玉林市| 尚义县| 滨海县| 来安县| 临澧县| 盐亭县| 石屏县| 彭水| 鄂托克前旗| 阳信县| 福泉市| 阆中市| 比如县| 洪洞县| 南汇区| 乌拉特前旗| 苏尼特右旗| 龙江县| 二连浩特市| 鸡泽县| 南江县| 通榆县| 浦县| 和平区| 沈丘县| 江达县|