内射老阿姨1区2区3区4区_久久精品人人做人人爽电影蜜月_久久国产精品亚洲77777_99精品又大又爽又粗少妇毛片

java實(shí)現(xiàn)二分法查找出數(shù)組重復(fù)數(shù)字

本文實(shí)例為大家分享了java實(shí)現(xiàn)二分法查找出數(shù)組重復(fù)數(shù)字的具體代碼,供大家參考,具體內(nèi)容如下

創(chuàng)新互聯(lián)建站專業(yè)為企業(yè)提供南木林網(wǎng)站建設(shè)、南木林做網(wǎng)站、南木林網(wǎng)站設(shè)計(jì)、南木林網(wǎng)站制作等企業(yè)網(wǎng)站建設(shè)、網(wǎng)頁(yè)設(shè)計(jì)與制作、南木林企業(yè)網(wǎng)站模板建站服務(wù),十余年南木林做網(wǎng)站經(jīng)驗(yàn),不只是建網(wǎng)站,更提供有價(jià)值的思路和整體網(wǎng)絡(luò)服務(wù)。

package offer;
/**
 * 二分查找的思想來(lái)找到數(shù)組中重復(fù)的數(shù)字,時(shí)間復(fù)雜度在o(nlogn)-o(n^2)
 */
public class FindDuplicate3 {
 public static void main(String[] args) {
 int numbers[] = {0,1,2,3,4,4,6,7};//數(shù)組中的數(shù) 大小從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)//當(dāng)兩個(gè)下標(biāo)值相等結(jié)束循環(huán)
 {
  if(countNumberInRange(numbers,left,right)>1)
  {  
  System.out.println(left);
  break;
  }
  else break;
 }
 //以下通過(guò)計(jì)算在指定區(qū)間數(shù)組中數(shù)字的個(gè)數(shù)與區(qū)間的長(zhǎng)度對(duì)比來(lái)確定數(shù)組中是否有重復(fù)數(shù)字
 if(countNumberInRange(numbers,left, mid)>(mid-left+1))//如果數(shù)字區(qū)間從left到 mid的數(shù)字個(gè)數(shù)大于mid-left+1 則本區(qū)間肯定與重復(fù)數(shù)字
 {
  right=mid;
 }
 else if(countNumberInRange(numbers,mid+1, right)>(right-mid))//如果數(shù)字區(qū)間從mid+1到right的數(shù)字個(gè)數(shù)大于right-mid則本區(qū)間肯定有重復(fù)數(shù)字
 {
  left=mid+1;
 }
 else if(countNumberInRange(numbers,left, mid)==(mid-left+1) && countNumberInRange(numbers,mid+1, right)==(right-mid))
 {//因?yàn)樯蟽蓚€(gè)判斷不能確定區(qū)間內(nèi)是每個(gè)數(shù)字各出現(xiàn)了一次還是某個(gè)數(shù)字出現(xiàn)了兩次,所以當(dāng)左右區(qū)間長(zhǎng)度與數(shù)字個(gè)數(shù)相等時(shí)不能排除仍然有重復(fù)數(shù)字
  if(countNumberInRange(numbers,right,right)>1)//判斷最后一個(gè)數(shù)字出現(xiàn)次數(shù)是否是多次
  {
  System.out.println(right);
  break;
  }
  else//縮減區(qū)間
 right=right-1;
 }
 }
 
 }
 //計(jì)算數(shù)組中在from到to區(qū)間數(shù)字的個(gè)數(shù)
 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;
 }
}

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持創(chuàng)新互聯(lián)。

網(wǎng)頁(yè)名稱:java實(shí)現(xiàn)二分法查找出數(shù)組重復(fù)數(shù)字
URL網(wǎng)址:http://www.rwnh.cn/article6/gspsig.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站維護(hù)網(wǎng)站排名、網(wǎng)站收錄、網(wǎng)站設(shè)計(jì)企業(yè)建站

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)

成都seo排名網(wǎng)站優(yōu)化
泸定县| 赣州市| 霍林郭勒市| 天峨县| 汶上县| 尚志市| 荆州市| 清丰县| 涟源市| 南阳市| 乃东县| 大方县| 芷江| 谷城县| 应用必备| 体育| 北碚区| 沾化县| 安顺市| 榕江县| 嵊泗县| 华安县| 济阳县| 志丹县| 吴旗县| 通州市| 合江县| 棋牌| 利津县| 怀集县| 察雅县| 中江县| 石城县| 察雅县| 陈巴尔虎旗| 周至县| 焉耆| 齐河县| 阆中市| 淮安市| 花莲市|