亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 開發 > Java > 正文

java實現二分法的完整代碼

2024-07-14 08:42:52
字體:
來源:轉載
供稿:網友

二分法查找,顧名思義就是要將數據每次都分成兩份然后再去找到你想要的數據,我們可以這樣去想,二分法查找很類似與我們平時玩的猜價格游戲,當你報出一個價格時裁判會告訴你價格相對于真實值的高低,倘若是低了那我們一定會再說出一個略高的價格,反之亦然。在二分法查找時要求傳入的數據必須已經有序,假設現在為升序,然后每次將所尋找的值與中間值(數組左邊界+(右邊界-左邊界)/2)作比較,大了則去尋找中間值左側數據,小則尋找中間值右側數據。

二分法查找比較局限性的就是只能操作一個已經排序了的數組。

方法一

下面為一個二分法實現的完整代碼

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為所要查找的數 { 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("請輸入數組長度"); q2= in.nextInt();  a=new int [q2];  out.println("請輸入數組元素");  for(int i=0;i<a.length;i++)  {  a[i]=in.nextInt();  }  out.println("排序后數組為");  Arrays.sort(a);  for (int i = 0; i < a.length; i++) {  out.print(a[i]+" ");  }  out.println();  out.println("請輸入所要查找的數若未查找到該數則輸出-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("所輸入的數在第"+p.find(a,q2)+"位"); }}

方法二

代碼實現:

public class BinarySearch {//進行二分法查找的前提是數組已經有序!	public static int rank(int key,int nums[])	{		//查找范圍的上下界		int low=0;		int high=nums.length-1;		//未查找到的返回值		int notFind=-1;		while(low<=high)		{			//二分中點=數組左邊界+(右邊界-左邊界)/2			//整數類型默認取下整			int mid=low+(high-low)/2;			//中間值是如果大于key			if(nums[mid]>key)			{				//證明key在[low,mid-1]這個區間				//因為num[mid]已經判斷過了所以下界要減一				high=mid-1;			}else if(nums[mid]<key)			{				//證明key在[mid+1,high]這個區間				//同樣判斷過mid對應的值要從mid+1往后判斷				low=mid+1;			}			else			{				//查找成功				return mid;			}		}		//未成功		return notFind;	}	public static void main(String[] args) {		System.out.println("請輸入數據數量:");		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("請輸入想要查找的值");		int key=scanner.nextInt();		int answer=rank(key,nums);		if(answer!=-1)		{			System.out.println("所查找的數據存在:"+nums[answer]);		}		else		{			System.out.println("您所查找的數據不存在");		}	} }

方法三、算法代碼實現之二分法查找

封裝成類:

package com.roc.algorithms.search; /** * 二分法查找 * * @author roc */public class BinarySearch {   /**   * @param a 升序排列的數組   * @param k 待查找的整數   * @return 如果查到有就返回對應角標,沒有就返回-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;  }}

測試:

int[] a = {0, 1, 2, 3, 4, 5, 6, 7, 8, 9};System.out.println(BinarySearch.search(a, 6));

輸出:

6

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持VeVb武林網。


注:相關教程知識閱讀請移步到JAVA教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
高潮白浆女日韩av免费看| 亚洲日本欧美日韩高观看| 国产啪精品视频网站| 亚洲精品永久免费精品| 视频在线观看一区二区| 成人精品视频在线| 国产欧洲精品视频| 欧洲日本亚洲国产区| 日韩欧美成人网| 日本中文字幕久久看| 一二美女精品欧洲| 日韩欧美在线第一页| 欧美激情xxxx性bbbb| 久久亚洲精品国产亚洲老地址| 亚洲成年人影院在线| 日韩精品亚洲精品| 亚洲伊人久久综合| 欧美高清电影在线看| 亚洲国产精品99| 久久成人精品电影| 91av在线看| 亚洲精品黄网在线观看| 亚洲精品乱码久久久久久按摩观| 亚洲а∨天堂久久精品9966| 日韩精品免费在线视频观看| 国产日本欧美一区二区三区在线| 国产精品美女久久久久av超清| 91国产视频在线| 亚洲一区二区免费在线| 亚洲第一黄色网| 成人做爰www免费看视频网站| 亚洲电影成人av99爱色| 色噜噜狠狠狠综合曰曰曰| 午夜精品久久久99热福利| 国产精品第100页| 日本乱人伦a精品| 九九九热精品免费视频观看网站| 久久九九全国免费精品观看| 亚洲男人的天堂在线播放| 日韩一区二区久久久| 久久精品福利视频| 日韩欧美在线免费观看| 日韩激情视频在线| 97久久久免费福利网址| 国模吧一区二区三区| 欲色天天网综合久久| 国产精品91久久久| 国产视频欧美视频| 国产成人一区二区三区| 亚洲免费视频一区二区| 日韩欧中文字幕| 538国产精品一区二区免费视频| 欧美成人高清视频| 国内免费精品永久在线视频| 不卡av电影院| 97超视频免费观看| 精品国偷自产在线视频| 97视频免费观看| 欧美一级视频免费在线观看| 成人黄色免费在线观看| 亚洲成人免费在线视频| 91超碰caoporn97人人| 夜夜嗨av一区二区三区四区| 日韩美女av在线免费观看| 欧美二区乱c黑人| 国产日韩欧美日韩大片| 91久久国产婷婷一区二区| 国产亚洲a∨片在线观看| 久久久久国色av免费观看性色| 成人a视频在线观看| 国产成人亚洲综合91精品| 久久99青青精品免费观看| 亚洲一级黄色av| 亚洲国产精品视频在线观看| 中文字幕成人精品久久不卡| 色综合男人天堂| 中文字幕日韩欧美| 欧美激情视频在线免费观看 欧美视频免费一| 成人av电影天堂| 日韩在线观看免费网站| 国产精选久久久久久| 国产99久久精品一区二区 夜夜躁日日躁| 久久夜精品va视频免费观看| 这里只有视频精品| 亚洲美女av电影| 亚洲人精品午夜在线观看| 亚洲国产精品一区二区三区| 日韩av在线最新| 久久影视电视剧免费网站清宫辞电视| 国产有码一区二区| 亚洲第一黄色网| 欧美日韩第一视频| 精品日本美女福利在线观看| 国产精品久久久久久久久久久不卡| 中文字幕欧美日韩精品| 国产精品久久久久久久一区探花| 亚洲综合小说区| 亚洲欧美日韩高清| 色香阁99久久精品久久久| 国产成人精品免费视频| 久久精品电影网站| 国产99久久精品一区二区永久免费| 搡老女人一区二区三区视频tv| 精品少妇一区二区30p| 精品国产乱码久久久久酒店| 成人av在线天堂| 亚洲免费精彩视频| 亚洲欧美日韩天堂一区二区| 国产亚洲福利一区| 久久视频在线观看免费| 亚洲国产古装精品网站| 亚洲人成电影在线播放| 91在线观看免费高清完整版在线观看| 久久精品视频播放| 欧美成人一区二区三区电影| 欧美日韩亚洲一区二| 国产精品av在线| 岛国av一区二区| 国产亚洲一区二区精品| 91精品91久久久久久| 国产有码在线一区二区视频| 亚洲黄页视频免费观看| 国产精品成人av在线| 国产成人a亚洲精品| 中文字幕亚洲在线| 91国产美女视频| 亚洲第一区第一页| 国产日韩在线视频| 亚洲人成电影网站色xx| 日韩欧美成人精品| 一区二区三区精品99久久| 亚洲人a成www在线影院| 亚洲一区制服诱惑| 成人国产精品色哟哟| 热re99久久精品国产66热| 91av成人在线| 精品久久久视频| 日韩在线视频观看正片免费网站| 国产精品三级美女白浆呻吟| 欧美激情二区三区| 亚洲视屏在线播放| 97在线免费观看视频| 91视频国产高清| 久久国产精彩视频| 亚洲激情成人网| 国产成人精品综合久久久| 成人av.网址在线网站| 三级精品视频久久久久| 亚洲国产高清高潮精品美女| 国产精品日韩一区| 欧美日韩成人免费| 亚洲成人1234| 久久久国产一区二区三区| 欧美性高潮在线| 2019国产精品自在线拍国产不卡| 国产不卡精品视男人的天堂| 55夜色66夜色国产精品视频| 欧美自拍大量在线观看| 欧美又大又硬又粗bbbbb| 在线色欧美三级视频| 欧美成人精品一区| 欧美国产日韩免费| 国产精品丝袜久久久久久不卡| 91精品国产高清自在线|