国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 開發 > Java > 正文

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

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

本文實例為大家分享了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; }}

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


注:相關教程知識閱讀請移步到JAVA教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 湘潭县| 兴海县| 泰和县| 彩票| 喀喇沁旗| 东乡县| 揭东县| 临夏县| 确山县| 威海市| 阿坝| 防城港市| 莱西市| 河间市| 长沙市| 辉南县| 衡山县| 康乐县| 水城县| 甘肃省| 彩票| 灯塔市| 龙州县| 达州市| 疏勒县| 迁安市| 安宁市| 昌邑市| 朔州市| 吉木萨尔县| 北流市| 玉树县| 台中市| 雅江县| 洛浦县| 板桥市| 丰台区| 石景山区| 渝中区| 永丰县| 铁力市|