二分尋找實現

來源:互聯網
上載者:User

看了“只有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;}}

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.