java實現(xiàn)二分法查找出數(shù)組重復數(shù)字
本文實例為大家分享了java實現(xiàn)二分法查找出數(shù)組重復數(shù)字的具體代碼,供大家參考,具體內(nèi)容如下
package offer; /** * 二分查找的思想來找到數(shù)組中重復的數(shù)字,時間復雜度在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)//當兩個下標值相等結(jié)束循環(huán) { if(countNumberInRange(numbers,left,right)>1) { System.out.println(left); break; } else break; } //以下通過計算在指定區(qū)間數(shù)組中數(shù)字的個數(shù)與區(qū)間的長度對比來確定數(shù)組中是否有重復數(shù)字 if(countNumberInRange(numbers,left, mid)>(mid-left+1))//如果數(shù)字區(qū)間從left到 mid的數(shù)字個數(shù)大于mid-left+1 則本區(qū)間肯定與重復數(shù)字 { right=mid; } else if(countNumberInRange(numbers,mid+1, right)>(right-mid))//如果數(shù)字區(qū)間從mid+1到right的數(shù)字個數(shù)大于right-mid則本區(qū)間肯定有重復數(shù)字 { left=mid+1; } else if(countNumberInRange(numbers,left, mid)==(mid-left+1) && countNumberInRange(numbers,mid+1, right)==(right-mid)) {//因為上兩個判斷不能確定區(qū)間內(nèi)是每個數(shù)字各出現(xiàn)了一次還是某個數(shù)字出現(xiàn)了兩次,所以當左右區(qū)間長度與數(shù)字個數(shù)相等時不能排除仍然有重復數(shù)字 if(countNumberInRange(numbers,right,right)>1)//判斷最后一個數(shù)字出現(xiàn)次數(shù)是否是多次 { System.out.println(right); break; } else//縮減區(qū)間 right=right-1; } } } //計算數(shù)組中在from到to區(qū)間數(shù)字的個數(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; } }
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Java復制(拷貝)數(shù)組的4種方法:arraycopy()方法、clone() 方法、copyOf()和copyOfRa
這篇文章主要介紹了Java復制(拷貝)數(shù)組的4種方法:arraycopy()方法、clone() 方法、copyOf()和copyOfRan,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2021-01-01使用AbstractRoutingDataSource實現(xiàn)數(shù)據(jù)源動態(tài)切換的實例
AbstractRoutingDataSource 是 Spring 框架提供的一個抽象類,用于實現(xiàn)動態(tài)數(shù)據(jù)源路由,這個類主要用于多數(shù)據(jù)源場景,其中可以根據(jù)不同的條件動態(tài)地切換到不同的數(shù)據(jù)源,本文給大家介紹了如何使用AbstractRoutingDataSource實現(xiàn)數(shù)據(jù)源動態(tài)切換,需要的朋友可以參考下2024-03-03JAVASE精密邏輯控制過程詳解(分支和循環(huán)語句)
在一個程序執(zhí)行的過程中各條語句的執(zhí)行順序?qū)Τ绦虻慕Y(jié)果是有直接影響的,這篇文章主要給大家介紹了關(guān)于JAVASE精密邏輯控制(分支和循環(huán)語句)的相關(guān)資料,文中通過代碼介紹的非常詳細,需要的朋友可以參考下2024-04-04Java數(shù)據(jù)結(jié)構(gòu)之循環(huán)隊列簡單定義與用法示例
這篇文章主要介紹了Java數(shù)據(jù)結(jié)構(gòu)之循環(huán)隊列簡單定義與用法,簡要描述了循環(huán)隊列的概念、原理,并結(jié)合實例形式分析了java循環(huán)隊列的定義與使用方法,需要的朋友可以參考下2017-10-10SpringBoot+thymeleaf+ajax實現(xiàn)局部刷新詳情
這篇文章主要介紹了SpringBoot+thymeleaf+ajax實現(xiàn)局部刷新詳情,文章圍繞主題展開詳細的內(nèi)容介紹具有一定的參考價值,需要的小伙伴可以參考一下2022-09-09Java擴展庫RxJava的基本結(jié)構(gòu)與適用場景小結(jié)
RxJava(GitHub: https://github.com/ReactiveX/RxJava)能夠幫助Java進行異步與事務驅(qū)動的程序編寫,這里我們來作一個Java擴展庫RxJava的基本結(jié)構(gòu)與適用場景小結(jié),剛接觸RxJava的同學不妨看一下^^2016-06-06