欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Java實(shí)現(xiàn)二分法變種的示例代碼

 更新時(shí)間:2024年04月30日 10:11:59   作者:一葉浮萍?xì)w大海  
這篇文章主要為大家介紹了Java實(shí)現(xiàn)二分法變種的示例代碼復(fù),有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪

一、引言

二分法,又稱二分查找、折半查找,是一種在有序數(shù)組中查找某一特定元素的搜索算法。其核心思想是通過(guò)將目標(biāo)數(shù)據(jù)與有序的數(shù)據(jù)序列進(jìn)行比較,每次查找都將數(shù)據(jù)序列一分為二,確定目標(biāo)數(shù)據(jù)在哪一半中,直到找到目標(biāo)數(shù)據(jù)或者確定目標(biāo)數(shù)據(jù)不存在。二分法的時(shí)間復(fù)雜度為O(log n),相比于順序查找的O(n),效率更高。然而,在實(shí)際應(yīng)用中,我們可能會(huì)遇到一些特殊情況,需要對(duì)二分法進(jìn)行一定的變種以滿足特定的需求。本文將介紹幾種常見(jiàn)的二分法變種,并給出Java實(shí)現(xiàn)。

二、二分法變種

  • 查找第一個(gè)等于給定值的元素

在某些情況下,我們不僅需要判斷數(shù)組中是否存在某個(gè)元素,還需要找到該元素在數(shù)組中的第一個(gè)位置。這可以通過(guò)在二分查找的基礎(chǔ)上稍作修改來(lái)實(shí)現(xiàn)。當(dāng)找到目標(biāo)元素時(shí),我們并不立即返回,而是繼續(xù)向左查找,直到找到第一個(gè)等于目標(biāo)值的元素。

Java實(shí)現(xiàn)如下:

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; // 繼續(xù)向左查找
        } else {
            left = mid + 1;
        }
    }
    // 檢查left是否越界以及nums[left]是否等于target
    if (left >= 0 && nums[left] == target) {
        return left;
    } else {
        return -1; // 未找到
    }
}
  • 查找最后一個(gè)等于給定值的元素

與查找第一個(gè)等于給定值的元素類似,我們也可以通過(guò)修改二分查找算法來(lái)找到最后一個(gè)等于給定值的元素。當(dāng)找到目標(biāo)元素時(shí),我們并不立即返回,而是繼續(xù)向右查找,直到找到最后一個(gè)等于目標(biāo)值的元素。

Java實(shí)現(xiàn)如下:

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; // 繼續(xù)向右查找
        }
    }
    // 檢查right是否越界以及nums[right]是否等于target
    if (right >= 0 && nums[right] == target) {
        return right;
    } else {
        return -1; // 未找到
    }
}
  • 查找插入位置

在某些情況下,我們需要在有序數(shù)組中插入一個(gè)元素,并返回插入后的索引。如果數(shù)組中已存在該元素,則返回該元素的索引;否則,返回應(yīng)該插入的位置。這同樣可以通過(guò)修改二分查找算法來(lái)實(shí)現(xiàn)。

Java實(shí)現(xiàn)如下:

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; // 找到目標(biāo)元素,返回其索引
        } else if (nums[mid] < target) {
            left = mid + 1; // 目標(biāo)元素在右半部分
        } else {
            right = mid - 1; // 目標(biāo)元素在左半部分或不存在(此時(shí)right指向的位置應(yīng)插入target)
        }
    }
    // 未找到目標(biāo)元素,返回應(yīng)插入的位置
    return left;
}

三、總結(jié)

本文介紹了三種常見(jiàn)的二分法變種:查找第一個(gè)等于給定值的元素、查找最后一個(gè)等于給定值的元素和查找插入位置,并給出了相應(yīng)的Java實(shí)現(xiàn)。這些變種算法都是在原始二分查找算法的基礎(chǔ)上進(jìn)行了一定的修改和擴(kuò)展,以滿足特定的需求。在實(shí)際應(yīng)用中,我們可以根據(jù)具體的問(wèn)題選擇合適的變種算法來(lái)解決問(wèn)題。

到此這篇關(guān)于Java實(shí)現(xiàn)二分法變種的示例代碼的文章就介紹到這了,更多相關(guān)Java 二分法變種內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Python用戶自定義異常的實(shí)現(xiàn)

    Python用戶自定義異常的實(shí)現(xiàn)

    這篇文章主要介紹了Python用戶自定義異常的實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2020-12-12
  • 在漏洞利用Python代碼真的很爽

    在漏洞利用Python代碼真的很爽

    在漏洞利用Python代碼真的很爽...
    2007-08-08
  • python+requests接口自動(dòng)化框架的實(shí)現(xiàn)

    python+requests接口自動(dòng)化框架的實(shí)現(xiàn)

    這篇文章主要介紹了python+requests接口自動(dòng)化框架的實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2020-08-08
  • PyCharm 2020.1版安裝破解注冊(cè)碼永久激活(激活到2089年)

    PyCharm 2020.1版安裝破解注冊(cè)碼永久激活(激活到2089年)

    這篇文章主要介紹了PyCharm 2020.1版安裝破解注冊(cè)碼永久激活(激活到2089年),需要的朋友可以參考下
    2020-09-09
  • Python中用startswith()函數(shù)判斷字符串開(kāi)頭的教程

    Python中用startswith()函數(shù)判斷字符串開(kāi)頭的教程

    這篇文章主要介紹了Python中用startswith()函數(shù)判斷字符串開(kāi)頭的教程,startswith()函數(shù)的使用是Python學(xué)習(xí)中的基礎(chǔ)知識(shí),本文列舉了一些不同情況下的使用結(jié)果,需要的朋友可以參考下
    2015-04-04
  • 詳解python基礎(chǔ)之while循環(huán)及if判斷

    詳解python基礎(chǔ)之while循環(huán)及if判斷

    這篇文章主要介紹了python基礎(chǔ)之while循環(huán)及if判斷的相關(guān)資料,需要的朋友可以參考下
    2017-08-08
  • matplotlib.pyplot.matshow 矩陣可視化實(shí)例

    matplotlib.pyplot.matshow 矩陣可視化實(shí)例

    這篇文章主要介紹了matplotlib.pyplot.matshow 矩陣可視化實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2020-06-06
  • Pyecharts?繪制3種常用的圖形

    Pyecharts?繪制3種常用的圖形

    這篇文章主要介紹了Pyecharts?繪制3種常用的圖形,上下組合圖、左右組合圖、一軸多圖,下文繪制過(guò)程幾介紹,需要的小伙伴可以參考一下
    2022-02-02
  • python 一些常用的小腳本

    python 一些常用的小腳本

    本文主要介紹了python 一些常用的小腳本,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2007-10-10
  • python字符串格式化方式解析

    python字符串格式化方式解析

    這篇文章主要介紹了python字符串格式化方式解析,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2019-10-10

最新評(píng)論