java二分法找数数_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

{

if(numbers[i]>=from && numbers[i]<=to)

count++;

}

return count;

}

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值