欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

java實(shí)現(xiàn)二分法的完整代碼

 更新時(shí)間:2018年11月16日 15:44:45   作者:心所向在腳下  
這篇文章主要為大家詳細(xì)介紹了java實(shí)現(xiàn)二分法的完整代碼,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下

二分法查找,顧名思義就是要將數(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)文章

  • java日期時(shí)間操作工具類

    java日期時(shí)間操作工具類

    這篇文章主要為大家詳細(xì)介紹了java日期時(shí)間操作工具類,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2018-12-12
  • @RequestBody不能映射到對(duì)象的解決

    @RequestBody不能映射到對(duì)象的解決

    這篇文章主要介紹了@RequestBody不能映射到對(duì)象的解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2021-10-10
  • SpringBoot常見(jiàn)問(wèn)題小結(jié)

    SpringBoot常見(jiàn)問(wèn)題小結(jié)

    這篇文章主要介紹了SpringBoot常見(jiàn)問(wèn)題小結(jié),需要的朋友可以參考下
    2017-07-07
  • SpringBoot使用JavaCV處理rtsp流的示例代碼

    SpringBoot使用JavaCV處理rtsp流的示例代碼

    這篇文章主要為大家詳細(xì)介紹了SpringBoot使用JavaCV處理rtsp流,文中的示例代碼講解詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴可以跟隨小編一起了解一下
    2024-02-02
  • Unity&Springboot實(shí)現(xiàn)本地登陸驗(yàn)證

    Unity&Springboot實(shí)現(xiàn)本地登陸驗(yàn)證

    本文主要介紹了Unity&Springboot服務(wù)器/本地登陸驗(yàn)證,文中通過(guò)示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-07-07
  • 自定義類加載器以及打破雙親委派模型解析

    自定義類加載器以及打破雙親委派模型解析

    這篇文章主要介紹了自定義類加載器以及打破雙親委派模型解析,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-11-11
  • Java 給PPT添加動(dòng)畫(huà)效果的示例

    Java 給PPT添加動(dòng)畫(huà)效果的示例

    這篇文章主要介紹了Java 給PPT添加動(dòng)畫(huà)效果的示例,幫助大家更好的理解和學(xué)習(xí)使用Java,感興趣的朋友可以了解下
    2021-04-04
  • Java 中模仿源碼自定義ArrayList

    Java 中模仿源碼自定義ArrayList

    這篇文章主要介紹了Java 中模仿源碼自定義ArrayList的相關(guān)資料,需要的朋友可以參考下
    2017-03-03
  • IDEA報(bào)錯(cuò):java:無(wú)效的源發(fā)行版21解決方式

    IDEA報(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-06
  • Java Lock接口實(shí)現(xiàn)原理及實(shí)例解析

    Java Lock接口實(shí)現(xiàn)原理及實(shí)例解析

    這篇文章主要介紹了Java Lock接口實(shí)現(xiàn)原理及實(shí)例解析,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-04-04

最新評(píng)論