java實現(xiàn)二分法查找出數(shù)組重復(fù)數(shù)字
更新時間:2018年11月17日 08:45:15 作者:longdragen
這篇文章主要為大家詳細介紹了java實現(xiàn)二分法查找出數(shù)組重復(fù)數(shù)字,具有一定的參考價值,感興趣的小伙伴們可以參考一下
本文實例為大家分享了java實現(xiàn)二分法查找出數(shù)組重復(fù)數(shù)字的具體代碼,供大家參考,具體內(nèi)容如下
package offer;
/**
* 二分查找的思想來找到數(shù)組中重復(fù)的數(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)//當兩個下標值相等結(jié)束循環(huán)
{
if(countNumberInRange(numbers,left,right)>1)
{
System.out.println(left);
break;
}
else break;
}
//以下通過計算在指定區(qū)間數(shù)組中數(shù)字的個數(shù)與區(qū)間的長度對比來確定數(shù)組中是否有重復(fù)數(shù)字
if(countNumberInRange(numbers,left, mid)>(mid-left+1))//如果數(shù)字區(qū)間從left到 mid的數(shù)字個數(shù)大于mid-left+1 則本區(qū)間肯定與重復(fù)數(shù)字
{
right=mid;
}
else if(countNumberInRange(numbers,mid+1, right)>(right-mid))//如果數(shù)字區(qū)間從mid+1到right的數(shù)字個數(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))
{//因為上兩個判斷不能確定區(qū)間內(nèi)是每個數(shù)字各出現(xiàn)了一次還是某個數(shù)字出現(xiàn)了兩次,所以當左右區(qū)間長度與數(shù)字個數(shù)相等時不能排除仍然有重復(fù)數(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)文章
如何修改json字符串中某個key對應(yīng)的value值
這篇文章主要介紹了如何修改json字符串中某個key對應(yīng)的value值操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-11-11
Java中的System.getenv()和System.getProperty()使用詳解
文章介紹了Java中用于讀取環(huán)境配置信息的兩種方法:System.getenv()和System.getProperty(),前者讀取系統(tǒng)環(huán)境變量,返回一個不可修改的Map;后者獲取JVM環(huán)境變量值,可以通過-D參數(shù)設(shè)置,文章還提到,通過這兩種方法可以簡化配置,不需要修改代碼2024-11-11
關(guān)于Springboot | @RequestBody 接收到的參數(shù)對象屬性為空的問題
這篇文章主要介紹了關(guān)于Springboot | @RequestBody 接收到的參數(shù)對象屬性為空的問題,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2021-03-03
SpringCloud?Tencent?全套解決方案源碼分析
Spring Cloud Tencent實現(xiàn)Spring Cloud標準微服務(wù)SPI,開發(fā)者可以基于Spring Cloud Tencent開發(fā)Spring Cloud微服務(wù)架構(gòu)應(yīng)用,Spring Cloud Tencent 的核心依托騰訊開源的一站式服務(wù)發(fā)現(xiàn)與治理平臺 Polarismesh,實現(xiàn)各種分布式微服務(wù)場景,感興趣的朋友一起看看吧2022-07-07
微服務(wù)領(lǐng)域Spring Boot自動伸縮的實現(xiàn)方法
這篇文章主要給大家介紹了關(guān)于微服務(wù)領(lǐng)域Spring Boot自動伸縮的實現(xiàn)方法,文中通過示例代碼介紹的非常詳細,對大家學習或者使用spring boot具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2018-10-10
Spring session實現(xiàn)共享單點登錄案例過程解析
這篇文章主要介紹了Spring session實現(xiàn)共享單點登錄案例過程解析,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下2020-07-07

