java实现二分法查找出数组重复数字
作者:longdragen 发布时间:2022-07-15 03:54:00
标签: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<numbers.length;i++)
{
if(numbers[i]>=from && numbers[i]<=to)
count++;
}
return count;
}
}
来源:https://blog.csdn.net/longdragen/article/details/77373846


猜你喜欢
- 单元测试是程序员对代码的自测,一般公司都会严格要求单元测试,这是对自己代码的负责,也是对代码的敬畏。一般单元测试都是测试Service层,下
- 今晚上在编写udp传输文件的时候发现无法用JSON传输字节数组,试了很多种办法都会报错,最后查资料找到了Base64这个类,这个类可以将字节
- const和readonly经常被用来修饰类的字段,两者有何异同呢?const1、声明const类型变量一定要赋初值吗?一定要赋初值publ
- 实例如下:public class DataTypeChangeHelper { /** * 将一个单字节的b
- Java高德地图Api的使用使用高德经纬度获取地址信息一些准备用到的常量 /** *
- Memento定义:memento是一个保存另外一个对象内部状态拷贝的对象,这样以后就可以将该对象恢复到原先保存的状态。Memento模式相
- asp.net页面中如何获取Excel表的内容,具体内容介绍如下所示:首先引用组件和命名空间using Microsoft.Office.I
- using System; using System.IO; namespace DelAllLrcFiles { class Progra
- 本文实例为大家分享了java实现随机数生成器的具体代码,供大家参考,具体内容如下自己编的随机数生成器,比较简陋,功能也单一,当作练手。App
- SpringBoot集成Redis 1.添加redis依赖<dependency> <groupId
- 1、背景一般情况下,有些搜索需求是需要根据拼音和中文来搜索的,那么在elasticsearch中是如何来实现基于拼音来搜索的呢?可以通过el
- Ribbon是Spring Cloud Netflix全家桶中负责负载均衡的组件,它是一组类库的集合。通过Ribbon,程序员能在不涉及到具
- 一、概述无意中翻到的FoldingLayout的介绍的博客,以及github地址。感觉很nice呀,于是花了点时间研究以及编写,本篇博客将带
- springboot加载yml文件获不到值今天使用spring boot读取yml文件,这种多层嵌套的竟然无法读取到(value注解spri
- 之前在Retrofit源码初探一文中我们提出了三个问题:什么时候开始将注解中参数拼装成http请求的信息的?如何产生发起http请求对象的?
- 在上个月的对C#开发微信门户及应用做了介绍,写过了几篇的随笔进行分享,由于时间关系,间隔了一段时间没有继续写这个系列的博客了,并不是对这个方
- 前情提要我们上节内容学习了如何创建\注册\读取bean我们发现bean对象操作十分的繁琐!所以我们这个章节,就带大家来了解更加简单的bean
- 一,项目简介经过调查研究进行开发设计的这款仓库管理系统,主要是为商家提供商品货物进销存的信息化管理,以便让商家在竞争如此激烈的今天占据一定的
- 1、@Component 是用在类上的@Component public class Student { private String na
- 项目中经常会使用到一对多的查询场景,但是PageHelper对这种嵌套查询的支持不够,如果是一对多的列表查询,返回的分页结果是不对的参考Gi