java.util.Arrays.binarySearch(T[] a, T key, Comparator<? super T> c)方法範例


java.util.Arrays.binarySearch(T[] a, T key, Comparator<? super T> c) 方法搜尋指定陣列,使用二進位制搜尋演算法來指定物件。該陣列必須根據在進行此呼叫之前指定的比較器按升序排列。如果不排序,則結果是不確定的。

宣告

以下是java.util.Arrays.binarySearch(super)方法的宣告

public static <T> int binarySearch(T[] a, T key, Comparator<? super T> c)

引數

  • a -- 這是要搜尋的陣列。

  • key -- 這是要搜尋的值。

  • c -- 這是用來對陣列進行排序的比較。 null值指示該元素的自然順序應該被使用。

返回值

此方法返回搜尋鍵的索引,如果它包含在陣列中,否則它返回(- (插入點)- 1)。插入點是在將鍵插入陣列的那一點:第一個元素比鍵大,或如果陣列中的所有元素都小於指定的鍵的索引大於a.length。

異常

  • ClassCastException -- 如果陣列包含不可相互比較使用指定的比較器或搜尋鍵是沒有可比性使用此比較陣列的元素的元素。

例子

下面的範例演示java.util.Arrays.binarySearch(super) 方法的用法。

package com.yiibai;

import java.util.Arrays;
import java.util.Comparator;

public class ArrayDemo {
   
   public static void main(String[] args) {

      // initializing unsorted short array
      Short shortArr[] = new Short[]{5, 2, 15, 52, 10};

      // use comparator as null, sorting as natural ordering
      Comparator<Short> comp = null;

      // sorting array
      Arrays.sort(shortArr, comp);

      // let us print all the elements available in list
      System.out.println("The sorted short array is:");
      for (short number : shortArr) {
         System.out.println("Number = " + number);
      }

      // entering the value to be searched 
      short searchVal = 15;
      
      int retVal = Arrays.binarySearch(shortArr, searchVal, comp);
      System.out.println("The index of element 15 is : " + retVal);
      
   }
}

讓我們來編譯和執行上面的程式,這將產生以下結果:

The sorted short array is:
Number = 2
Number = 5
Number = 10
Number = 15
Number = 52
The index of element 15 is : 3