java實(shí)現(xiàn)二分法的完整代碼
二分法查找,顧名思義就是要將數(shù)據(jù)每次都分成兩份然后再去找到你想要的數(shù)據(jù),我們可以這樣去想,二分法查找很類似與我們平時(shí)玩的猜價(jià)格游戲,當(dāng)你報(bào)出一個(gè)價(jià)格時(shí)裁判會(huì)告訴你價(jià)格相對(duì)于真實(shí)值的高低,倘若是低了那我們一定會(huì)再說(shuō)出一個(gè)略高的價(jià)格,反之亦然。在二分法查找時(shí)要求傳入的數(shù)據(jù)必須已經(jīng)有序,假設(shè)現(xiàn)在為升序,然后每次將所尋找的值與中間值(數(shù)組左邊界+(右邊界-左邊界)/2)作比較,大了則去尋找中間值左側(cè)數(shù)據(jù),小則尋找中間值右側(cè)數(shù)據(jù)。
二分法查找比較局限性的就是只能操作一個(gè)已經(jīng)排序了的數(shù)組。
方法一
下面為一個(gè)二分法實(shí)現(xiàn)的完整代碼
package dichotomy; import java.util.Arrays; import java.util.Scanner; import static java.lang.System.out; public class Erchange { private static Scanner in; public int find(int a[],int b) //a為所要查找的數(shù) { int mid,low=0,high; high=a.length-1; while(low<=high) { mid=low+(high-low)/2; if(b<a[mid]) { high=mid-1; } else if(b>a[mid]) { low=mid+1; } else { return mid+1; } } return 0; } public static void main(String[] args) { int a[]; int t; int sum=0; Erchange p=new Erchange(); int q2 = 0; in = new Scanner(System.in); out.println("請(qǐng)輸入數(shù)組長(zhǎng)度"); q2= in.nextInt(); a=new int [q2]; out.println("請(qǐng)輸入數(shù)組元素"); for(int i=0;i<a.length;i++) { a[i]=in.nextInt(); } out.println("排序后數(shù)組為"); Arrays.sort(a); for (int i = 0; i < a.length; i++) { out.print(a[i]+" "); } out.println(); out.println("請(qǐng)輸入所要查找的數(shù)若未查找到該數(shù)則輸出-1"); q2=in.nextInt(); for(int i=0;i<a.length;i++) { if(q2==a[i]) { t=1; } else { t=0; } sum=sum+t; } if(sum==0) { out.println("-1"); } else { out.println("所輸入的數(shù)在第"+p.find(a,q2)+"位"); } }
方法二
代碼實(shí)現(xiàn):
public class BinarySearch { //進(jìn)行二分法查找的前提是數(shù)組已經(jīng)有序! public static int rank(int key,int nums[]) { //查找范圍的上下界 int low=0; int high=nums.length-1; //未查找到的返回值 int notFind=-1; while(low<=high) { //二分中點(diǎn)=數(shù)組左邊界+(右邊界-左邊界)/2 //整數(shù)類型默認(rèn)取下整 int mid=low+(high-low)/2; //中間值是如果大于key if(nums[mid]>key) { //證明key在[low,mid-1]這個(gè)區(qū)間 //因?yàn)閚um[mid]已經(jīng)判斷過(guò)了所以下界要減一 high=mid-1; }else if(nums[mid]<key) { //證明key在[mid+1,high]這個(gè)區(qū)間 //同樣判斷過(guò)mid對(duì)應(yīng)的值要從mid+1往后判斷 low=mid+1; } else { //查找成功 return mid; } } //未成功 return notFind; } public static void main(String[] args) { System.out.println("請(qǐng)輸入數(shù)據(jù)數(shù)量:"); Scanner scanner=new Scanner(System.in); int amount=scanner.nextInt(); int num; int nums[]=new int[amount]; int i=0; while(i<amount) { nums[i]=scanner.nextInt(); i++; } Arrays.sort(nums); System.out.println("請(qǐng)輸入想要查找的值"); int key=scanner.nextInt(); int answer=rank(key,nums); if(answer!=-1) { System.out.println("所查找的數(shù)據(jù)存在:"+nums[answer]); } else { System.out.println("您所查找的數(shù)據(jù)不存在"); } } }
方法三、算法代碼實(shí)現(xiàn)之二分法查找
封裝成類:
package com.roc.algorithms.search; /** * 二分法查找 * * @author roc */ public class BinarySearch { /** * @param a 升序排列的數(shù)組 * @param k 待查找的整數(shù) * @return 如果查到有就返回對(duì)應(yīng)角標(biāo),沒(méi)有就返回-1 */ public static int search(int[] a, int k) { int lo = 0, hi = a.length - 1; while (lo <= hi) { int m = (lo + hi) >> 1; if (a[m] < k) { lo = m + 1; } else if (a[m] > k) { hi = m - 1; } else { return m; } } return -1; } }
測(cè)試:
int[] a = {0, 1, 2, 3, 4, 5, 6, 7, 8, 9}; System.out.println(BinarySearch.search(a, 6));
輸出:
6
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
SpringBoot常見(jiàn)問(wèn)題小結(jié)
這篇文章主要介紹了SpringBoot常見(jiàn)問(wèn)題小結(jié),需要的朋友可以參考下2017-07-07SpringBoot使用JavaCV處理rtsp流的示例代碼
這篇文章主要為大家詳細(xì)介紹了SpringBoot使用JavaCV處理rtsp流,文中的示例代碼講解詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴可以跟隨小編一起了解一下2024-02-02Unity&Springboot實(shí)現(xiàn)本地登陸驗(yàn)證
本文主要介紹了Unity&Springboot服務(wù)器/本地登陸驗(yàn)證,文中通過(guò)示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-07-07IDEA報(bào)錯(cuò):java:無(wú)效的源發(fā)行版21解決方式
這篇文章主要給大家介紹了關(guān)于IDEA報(bào)錯(cuò):java:無(wú)效的源發(fā)行版21的解決方式,這個(gè)錯(cuò)誤是因?yàn)槟愕捻?xiàng)目使用的Java版本與你的IDEA使用的Java版本不一致導(dǎo)致的,文中通過(guò)圖文介紹的非常詳細(xì),需要的朋友可以參考下2024-06-06Java Lock接口實(shí)現(xiàn)原理及實(shí)例解析
這篇文章主要介紹了Java Lock接口實(shí)現(xiàn)原理及實(shí)例解析,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-04-04