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中使用redis的方法代码详解

    springboot中使用redis的方法代码详解

    &#8203;redis 作为一个高性能的内存数据库,如果不会用就太落伍了,之前在 node.js 中用过 redis,本篇记录如何将 redis 集成到 spring boot 中。感兴趣的朋友跟随小编一起看看吧
    2019-05-05
  • Java使用Log4j记录日志的方法详解

    Java使用Log4j记录日志的方法详解

    log4j是一个常用的日志框架,用于记录应用程序的执行过程或异常等记录在日志文件中。本文将利用Log4j记录日志,感兴趣的可以了解一下
    2022-03-03
  • JavaApi实现更新删除及读取节点

    JavaApi实现更新删除及读取节点

    这篇文章主要介绍了JavaApi实现更新删除及读取节点,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-05-05
  • Java实现二维码生成的代码方法

    Java实现二维码生成的代码方法

    这篇内容分享了JAVA实现二维码生成的实例代码,对此有需要的朋友们可以测试参考下。
    2018-07-07
  • Java反射的使用和原理详解

    Java反射的使用和原理详解

    这篇文章主要介绍了Java反射的使用和原理详解,反射是java语言的一个特性,它允程序在运行时(注意不是编译的时候)来进行自我检查并且对内部的成员进行操作,需要的朋友可以参考下
    2024-01-01
  • MyBatis不同Mapper文件引用resultMap实例代码

    MyBatis不同Mapper文件引用resultMap实例代码

    这篇文章主要介绍了mybatis 不同Mapper文件引用resultMap的实例代码,非常不错具有参考借鉴价值,需要的朋友可以参考下
    2017-07-07
  • SpringBoot对接Spark过程详解

    SpringBoot对接Spark过程详解

    这篇文章主要介绍SpringBoot接入Spark的方法的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望能帮助大家解决问题
    2023-02-02
  • Java实现将彩色PDF转为灰度PDF的示例代码

    Java实现将彩色PDF转为灰度PDF的示例代码

    本文以Java代码为例介绍如何实现将彩色PDF文件转为灰度(黑白)的PDF文件,文中的示例代码讲解详细,感兴趣的小伙伴快跟随小编一起学习一下吧
    2022-03-03
  • Java实现扑克牌洗牌和发牌

    Java实现扑克牌洗牌和发牌

    这篇文章主要为大家详细介绍了Java实现扑克牌洗牌和发牌,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2020-04-04
  • 2022年最新java 8 ( jdk1.8u321)安装图文教程

    2022年最新java 8 ( jdk1.8u321)安装图文教程

    这篇文章主要介绍了2022年最新java 8 ( jdk1.8u321)安装图文教程,截止2022年1月,官方出的jdk1.8目前已更新到8u321的版本,本文通过图文并茂的形式给大家介绍安装过程,需要的朋友可以参考下
    2022-08-08

最新评论