亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

java實現二分法查找出數組重復數字

發布時間:2020-09-29 11:05:27 來源:腳本之家 閱讀:200 作者:longdragen 欄目:編程語言

本文實例為大家分享了java實現二分法查找出數組重復數字的具體代碼,供大家參考,具體內容如下

package offer;
/**
 * 二分查找的思想來找到數組中重復的數字,時間復雜度在o(nlogn)-o(n^2)
 */
public class FindDuplicate3 {
 public static void main(String[] args) {
 int numbers[] = {0,1,2,3,4,4,6,7};//數組中的數 大小從0 到 numbers.length-1
 findDuplicate(numbers,0,numbers.length-1);
 }
 static void findDuplicate(int numbers[],int left,int right){
 if (numbers == null || numbers.length == 0)
 return;
 int mid; 
 while(left<=right)
 { 
 System.out.println("Find duplicate from "+left+" to "+right);
 mid=(left+right)/2;
 if(left==right)//當兩個下標值相等結束循環
 {
  if(countNumberInRange(numbers,left,right)>1)
  {  
  System.out.println(left);
  break;
  }
  else break;
 }
 //以下通過計算在指定區間數組中數字的個數與區間的長度對比來確定數組中是否有重復數字
 if(countNumberInRange(numbers,left, mid)>(mid-left+1))//如果數字區間從left到 mid的數字個數大于mid-left+1 則本區間肯定與重復數字
 {
  right=mid;
 }
 else if(countNumberInRange(numbers,mid+1, right)>(right-mid))//如果數字區間從mid+1到right的數字個數大于right-mid則本區間肯定有重復數字
 {
  left=mid+1;
 }
 else if(countNumberInRange(numbers,left, mid)==(mid-left+1) && countNumberInRange(numbers,mid+1, right)==(right-mid))
 {//因為上兩個判斷不能確定區間內是每個數字各出現了一次還是某個數字出現了兩次,所以當左右區間長度與數字個數相等時不能排除仍然有重復數字
  if(countNumberInRange(numbers,right,right)>1)//判斷最后一個數字出現次數是否是多次
  {
  System.out.println(right);
  break;
  }
  else//縮減區間
 right=right-1;
 }
 }
 
 }
 //計算數組中在from到to區間數字的個數
 static int countNumberInRange(int numbers[],int from,int to)
 {
 int count=0;
 if(numbers==null || numbers.length==0)
 return 0;
 for(int i=0;i<numbers.length;i++)
 {
 if(numbers[i]>=from && numbers[i]<=to)
 count++;
 }
 return count;
 }
}

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

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

潞西市| 德江县| 略阳县| 固镇县| 临海市| 阿图什市| 雅江县| 巩义市| 安塞县| 宜阳县| 墨脱县| 嵊泗县| 犍为县| 手游| 库伦旗| 若尔盖县| 宣威市| 体育| 江津市| 民乐县| 泰来县| 通州市| 奉新县| 晋宁县| 崇信县| 壶关县| 沁源县| 广饶县| 缙云县| 朔州市| 邻水| 兴和县| 东乡族自治县| 修文县| 满城县| 大荔县| 海丰县| 高雄县| 望江县| 聂荣县| 彰化市|