Java实现二分法变种的示例代码

 更新时间:2024年04月30日 10:14:05   作者:一叶浮萍归大海  
这篇文章主要为大家介绍了Java实现二分法变种的示例代码复,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪

一、引言

二分法,又称二分查找、折半查找,是一种在有序数组中查找某一特定元素的搜索算法。其核心思想是通过将目标数据与有序的数据序列进行比较,每次查找都将数据序列一分为二,确定目标数据在哪一半中,直到找到目标数据或者确定目标数据不存在。二分法的时间复杂度为O(log n),相比于顺序查找的O(n),效率更高。然而,在实际应用中,我们可能会遇到一些特殊情况,需要对二分法进行一定的变种以满足特定的需求。本文将介绍几种常见的二分法变种,并给出Java实现。

二、二分法变种

  • 查找第一个等于给定值的元素

在某些情况下,我们不仅需要判断数组中是否存在某个元素,还需要找到该元素在数组中的第一个位置。这可以通过在二分查找的基础上稍作修改来实现。当找到目标元素时,我们并不立即返回,而是继续向左查找,直到找到第一个等于目标值的元素。

Java实现如下:

public int findFirstEqual(int[] nums, int target) {
    int left = 0, right = nums.length - 1;
    while (left <= right) {
        int mid = left + (right - left) / 2;
        if (nums[mid] >= target) {
            right = mid - 1; // 继续向左查找
        } else {
            left = mid + 1;
        }
    }
    // 检查left是否越界以及nums[left]是否等于target
    if (left >= 0 && nums[left] == target) {
        return left;
    } else {
        return -1; // 未找到
    }
}
  • 查找最后一个等于给定值的元素

与查找第一个等于给定值的元素类似,我们也可以通过修改二分查找算法来找到最后一个等于给定值的元素。当找到目标元素时,我们并不立即返回,而是继续向右查找,直到找到最后一个等于目标值的元素。

Java实现如下:

public int findLastEqual(int[] nums, int target) {
    int left = 0, right = nums.length - 1;
    while (left <= right) {
        int mid = left + (right - left) / 2;
        if (nums[mid] > target) {
            right = mid - 1;
        } else {
            left = mid + 1; // 继续向右查找
        }
    }
    // 检查right是否越界以及nums[right]是否等于target
    if (right >= 0 && nums[right] == target) {
        return right;
    } else {
        return -1; // 未找到
    }
}
  • 查找插入位置

在某些情况下,我们需要在有序数组中插入一个元素,并返回插入后的索引。如果数组中已存在该元素,则返回该元素的索引;否则,返回应该插入的位置。这同样可以通过修改二分查找算法来实现。

Java实现如下:

public int searchInsert(int[] nums, int target) {
    int left = 0, right = nums.length - 1;
    while (left <= right) {
        int mid = left + (right - left) / 2;
        if (nums[mid] == target) {
            return mid; // 找到目标元素,返回其索引
        } else if (nums[mid] < target) {
            left = mid + 1; // 目标元素在右半部分
        } else {
            right = mid - 1; // 目标元素在左半部分或不存在(此时right指向的位置应插入target)
        }
    }
    // 未找到目标元素,返回应插入的位置
    return left;
}

三、总结

本文介绍了三种常见的二分法变种:查找第一个等于给定值的元素、查找最后一个等于给定值的元素和查找插入位置,并给出了相应的Java实现。这些变种算法都是在原始二分查找算法的基础上进行了一定的修改和扩展,以满足特定的需求。在实际应用中,我们可以根据具体的问题选择合适的变种算法来解决问题。

到此这篇关于Java实现二分法变种的示例代码的文章就介绍到这了,更多相关Java 二分法变种内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • springboot学习之构建简单项目搭建步骤详解

    springboot学习之构建简单项目搭建步骤详解

    这篇文章主要介绍了springboot学习之构建简单项目搭建步骤详解,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-10-10
  • Java线程池Executor用法详解

    Java线程池Executor用法详解

    本文主要为大家详细介绍了Java线程池Executor的用法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2022-08-08
  • SpringBoot使用freemarker导出word文件方法详解

    SpringBoot使用freemarker导出word文件方法详解

    这篇文章主要介绍了SpringBoot使用freemarker导出word文件方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习吧
    2022-11-11
  • 深入了解Java SpringBoot自动装配原理

    深入了解Java SpringBoot自动装配原理

    在使用springboot时,很多配置我们都没有做,都是springboot在帮我们完成,这很大一部分归功于springboot自动装配。本文将详细为大家讲解SpringBoot的自动装配原理,需要的可以参考一下
    2022-03-03
  • MyBatis3.X复杂Sql查询的语句

    MyBatis3.X复杂Sql查询的语句

    这篇文章主要介绍了MyBatis3.X复杂Sql查询的相关资料,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2021-04-04
  • SpringBoot自定义MessageConverter与内容协商管理器contentNegotiationManager详解

    SpringBoot自定义MessageConverter与内容协商管理器contentNegotiationManag

    这篇文章主要介绍了SpringBoot自定义MessageConverter与内容协商管理器contentNegotiationManager的使用,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习吧
    2022-10-10
  • drools规则动态化实践解析

    drools规则动态化实践解析

    这篇文章主要为大家介绍了drools规则动态化实践解析,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-02-02
  • 一文详解Java对象的序列化和反序列化

    一文详解Java对象的序列化和反序列化

    本文主要介绍了一文详解Java对象的序列化和反序列化,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-04-04
  • Java-JFrame窗体美化方式

    Java-JFrame窗体美化方式

    这篇文章主要介绍了Java-JFrame窗体美化方式,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-11-11
  • SpringBoot定时调度之Timer与Quartz详解

    SpringBoot定时调度之Timer与Quartz详解

    Java 中常用的定时调度框架有以下几种:Timer、ScheduledExecutorService、Spring Task和Quartz,本文主要来和大家讲讲他们的具体使用,需要的可以参考一下
    2023-06-06

最新评论