看了“只有10%程式員能正確實現二分尋找演算法“這篇文章,閑著無聊,就實現一下他所說的正確的二分演算法;
其實說穿了為什麼只有10%的程式員會寫錯,只是因為沒有考慮一些意外情況罷了;
思想:
二分尋找能解決問題:預排序數組的尋找
1.使用泛型將二分尋找的對象泛化.
2.考慮以下幾種意外情況:
如果數組為null,則拋異常;
如果沒有找到,則返回-1;
其實我也不清楚有沒有bug...如果有人發現了,就指出吧。
package com.xiazdong.binarysearch.util;public class BinarySearchUtil<T> {/** * 使用執行個體 * BinarySearchUtil<Integer> bs = new BinarySearchUtil<Integer>(); * int position = bs.binarySearch(new Integer[]{1,2,3,4,5},2); * * 註: * class A implements Comparable{ * public int compareTo(A a){ * this 與 a比較 * 如果this<a , 則返回-1 * 如果this==a,則返回 0 * 如果this>a ,則返回 1 * } * } * @param <T> 任何實現了Comparable<T>的類型 * @param arr 數組 * @param key 尋找的值 * @return 如果找到了,返迴響應位置,如果沒有找到,則返回-1 */public static <T extends Comparable<T>> int binarySearch(T [] arr, T key) {if(arr==null){//數組不可為空throw new NullPointerException("數組不可為空");}int begin = 0;int end = arr.length - 1;int midden = (begin+end)/2;while(begin<=end){if(arr[midden].compareTo(key)==0){return midden;}else if(arr[midden].compareTo(key)<0){begin = midden+1;}else if(arr[midden].compareTo(key)>0){end = midden-1;}midden = (begin+end)/2;}return -1;}}