算法入門:二分查找及其Java實現

在程序開發中,算法是解決問題的核心。本篇博客將詳細講解一種高效的查找算法——二分查找,并通過Java代碼示例幫助你理解其實現和應用。


如果你覺得這篇文章對你有幫助,不要忘記點贊、收藏和關注我,這將是對我最大的支持和鼓勵!

什么是算法?

算法是解決問題的一系列步驟或規則。它們是計算機程序的核心,決定了程序的性能和效率。一個好的算法可以極大地提高程序的運行速度和資源利用率。

大O表示法

大O表示法用于描述算法的效率,特別是它在數據規模增長時的表現。常見的大O表示法包括:

  • O(1):常數時間,不論數據規模多大,執行時間都不變。
  • O(log n):對數時間,常見于二分查找。
  • O(n):線性時間,算法的執行時間與數據規模成正比。
  • O(n log n):線性對數時間,常見于快速排序、歸并排序等。
  • O(n^2):平方時間,常見于簡單排序算法,如冒泡排序。
  • O(2^n):指數時間,常見于解決復雜問題的遞歸算法。

二分查找簡介

二分查找是一種用于在有序數組中查找特定元素的高效算法。其基本思想是通過逐步縮小查找范圍,將查找時間復雜度降低到 O(log n)。相比于線性查找的 O(n),二分查找的效率要高得多。

二分查找步驟

  1. 找到數組的中間元素。
  2. 如果中間元素正好是目標元素,查找成功。
  3. 如果目標元素比中間元素小,則在左半部分繼續查找。
  4. 如果目標元素比中間元素大,則在右半部分繼續查找。
  5. 重復上述步驟,直到找到目標元素或范圍縮小為零。

二分查找圖解

在這里插入圖片描述

Java實現

下面是一個簡單的Java代碼實現:

public class BinarySearch {public static int binarySearch(int[] array, int target) {int low = 0;int high = array.length - 1;while (low <= high) {int mid = (low + high) / 2;int guess = array[mid];if (guess == target) {return mid;} else if (guess > target) {high = mid - 1;} else {low = mid + 1;}}return -1; // 表示未找到}public static void main(String[] args) {int[] array = {1, 3, 5, 7, 9};int target = 7;int result = binarySearch(array, target);System.out.println("元素 " + target + " 的索引為: " + result);}
}

代碼解釋

  1. binarySearch 方法接受一個有序數組和一個目標值作為輸入。
  2. 通過初始化 lowhigh 指針,逐步縮小查找范圍。
  3. 計算中間位置 mid 并檢查其值是否等于目標值。
  4. 根據目標值與中間值的比較結果,調整 lowhigh 指針。
  5. 循環直到找到目標值或范圍縮小為零。

算法分析

  • 時間復雜度:二分查找的時間復雜度為 O(log n),因為每次查找都會將查找范圍減半。
  • 空間復雜度:二分查找的空間復雜度為 O(1),因為它只使用了常數的額外空間。

示例運行結果

運行上述代碼,你將看到以下輸出:

元素 7 的索引為: 3

練習題

  1. 修改 binarySearch 方法,使其能處理包含重復元素的數組,并返回第一個匹配的元素。
  2. 實現一個線性查找算法,并比較它與二分查找的性能。

總結

通過本文的學習,我們了解了二分查找的基本概念、實現步驟和Java代碼示例。二分查找是一種高效的查找算法,適用于大多數有序數據集的查找問題。


如果你覺得這篇文章對你有幫助,請點贊、收藏,并關注我的CSDN博客。我會持續分享更多高質量的算法和編程知識。

感謝你的閱讀和支持!如果有任何問題或建議,歡迎在評論區留言,我會盡快回復。

希望這篇博客對你有幫助。如果有任何問題或需要進一步的解釋,請告訴我!

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/diannao/36663.shtml
繁體地址,請注明出處:http://hk.pswp.cn/diannao/36663.shtml
英文地址,請注明出處:http://en.pswp.cn/diannao/36663.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

VMware 最新的安全漏洞公告VMSA-2024-0013

#深度好文計劃# 一、摘要 2024年6月26日&#xff0c;VMware 發布了最新的安全漏洞公告 VMSA-2024-0013&#xff0c;修復了 VMware ESXi 和 VMware vCenter 中的多個安全漏洞。 VMSA-2024-0013&#xff1a;VMware ESXi 和 vCenter Server 更新修正了多個安全性漏洞 &#xff…

Unity3D 物體的運動

運動方式1 修改 position / localPosition &#xff0c;可以讓物體運動 例如&#xff0c; Vector3 pos this.transform.localPosition; pos.z distance; this.transform.localPosition pos; 此時&#xff0c;小車向Z 方向運動 具體代碼如下 using System.Collection…

C語言入門課程學習筆記10:結構體聯合體位域

C語言入門課程學習筆記10 第48課 - 自定義數據類型&#xff08;上&#xff09;實驗-typedef實驗小結 第49課 - 自定義數據類型&#xff08;中&#xff09;實驗實驗小結 第50課 - 自定義數據類型&#xff08;下&#xff09;實驗實驗小結 第51課 - 多文件程序設計實驗實驗實驗小結…

uni-app picker多列選項

預期實現的效果&#xff1a; 選中后的效果&#xff1a; // Dom部分 <template><picker mode"multiSelector" :range"ssqRange" range-key"name" columnchange"ssqColumnChange" change"ssqChange" class"p…

研究發現GPT-4o等較新的多模態AI模型的安全機制有不足之處

在 ChatGPT 和類似的生成式人工智能模型推出后&#xff0c;很多人都在強調安全問題&#xff0c;政府也參與其中&#xff0c;OpenAI 甚至成立了一個超級協調小組&#xff0c;以阻止未來的人工智能失控&#xff0c;但由于對人工智能安全的發展方向存在分歧&#xff0c;該小組于今…

03邏輯門電路

分立門電路&#xff1a; 集成門電路&#xff1a; TTL門電路 MOS門電路&#xff1a;NMOS門電路、PMOS門電路、CMOS門電路 BICMOS門電路&#xff1a;CMOS的高輸入阻抗和TTL的高放大倍數的結合 向更低功耗、更高速度發展 MOS管的Rdson在可變電阻區的阻值也一般會小于1000歐姆 …

達夢數據庫的系統視圖v$locked_object

達夢數據庫的系統視圖v$locked_object 在達夢數據庫&#xff08;Dameng Database&#xff09;中&#xff0c;V$LOCKED_OBJECT 視圖提供了與數據庫中被鎖定對象相關的信息。這通常用于監控和診斷數據庫中的鎖定問題&#xff0c;幫助管理員了解哪些對象被鎖定了&#xff0c;以及…

1.回溯算法.基礎

1.回溯算法 基礎知識題目1.組合2.組合-優化3.組合總和|||4.電話號碼和字母組合5.組合總和6.組合總和II7.分割回文串8.復原IP地址 基礎知識 回溯法也可以叫做回溯搜索法&#xff0c;它是一種搜索的方式。回溯是遞歸的副產品&#xff0c;只要有遞歸就會有回溯 因為回溯的本質是窮…

Excel 宏錄制與VBA編程 —— 11、工作表及工作簿操作(附:Worksheets與Sheets區別)

代碼1 - Worksheets與Sheets區別 Worksheets表示普通工作表;Sheets即可表示普通工作表也可表示圖標工作表。 下面模塊中代碼結果是一樣的,大家理解時可結合上面區別說明進行了解 Sub Test()Worksheets("Sheet1").Range("A1").Value 100Sheets("Sheet…

BioCLIP:物種圖像的基礎視覺模型

從無人機到個人手機&#xff0c;各種相機收集的自然世界圖像是越來越豐富的生物信息來源。從圖像中提取生物相關信息用于科學的計算方法和工具激增&#xff0c;尤其是計算機視覺。然而&#xff0c;其中大多數都是為特定任務設計的&#xff0c;不容易適應或擴展到新的問題、環境…

【編程知識】什么是編譯型語言?什么是解釋型語言?

1.編譯型語言&#xff1a; 源代碼由編譯器編譯為機器代碼&#xff08;中間代碼&#xff09;&#xff0c;生成可執行文件&#xff0c;后面的執行無需編譯&#xff0c;可以直接運行&#xff0c;無需依賴源代碼或編譯器。 執行速度更快&#xff0c;因為在執行前已經有一步編譯階段…

運維團隊如何加強安全設備監控與日志管理

隨著信息技術的飛速發展&#xff0c;網絡安全問題日益凸顯&#xff0c;安全設備的監控和日志管理成為了運維團隊不可或缺的工作內容。本文將結合運維行業的實際需求&#xff0c;探討如何加強安全設備監控與日志管理&#xff0c;以提升系統的安全性和穩定性。 一、安全設備監控…

git 本地代碼管理

簡介 git 能實現本地代碼多個更改版本的管理和導出。 首先復制好項目&#xff08;參考 git clone 別人項目后正確的修改和同步操作 中的前三步&#xff09; 實操 克隆原始項目 首先&#xff0c;從遠程倉庫克隆項目到本地&#xff1a; git clone https://github.com/libo-huan…

【AI大模型】Transformers大模型庫(十二):Evaluate模型評估

目錄 一、引言 二、Evaluate模型評估 2.1 概述 2.2 使用方法 2.2.1 步驟1: 導入必要的庫 2.2.2 步驟2: 加載模型和分詞器 2.2.3 步驟3: 準備數據集 2.2.4 步驟4: 數據預處理 2.2.5 步驟5: 創建訓練和評估數據集 2.2.6 步驟6: 設置訓練參數并創建Trainer 2.2.7 步…

基于Flask開發的前后端交互項目(可用于期末大作業) MySQL數據庫 文件上傳 Spider爬蟲 Echarts可視化展示 JS動態

項目描述&#xff1a; 開發一個基于Flask框架開發的前后端交互項目&#xff0c;項目內容為 東京奧運會 。對各個需要填寫的字段做了數據驗證&#xff0c;非法信息會被JS攔截提醒不合法&#xff1b;還對未登錄就訪問做了攔截&#xff0c;阻止未登錄就訪問。 前端&#xff1a;HT…

idea 開發工具properties文件中的中文不顯示

用idea打開一個項目&#xff0c;配置文件propertise中的中文都不展示&#xff0c;如圖&#xff1a; 可修改idea配置讓中文顯示&#xff1a; 勾選箭頭指向的框即可&#xff0c;點擊應用保存&#xff0c;重新打開配置文件&#xff0c;顯示正常

Java開發環境配置

一、JDK 下載JDK&#xff1a;Java Downloads | Oracle 配置環境變量&#xff1a;09、Java入門&#xff1a;Path、JAVA_HOME環境變量配置_嗶哩嗶哩_bilibili 二、IDEA 下載IDEA&#xff1a; Download IntelliJ IDEA – The Leading Java and Kotlin IDE (jetbrains.com) 建…

HotSpot 垃圾收集器

文章目錄 前言HotSpot 垃圾收集器1. 查看jdk默認垃圾收集器命令2. 查看當前服務使用的是哪個垃圾收集器:3. 常用的垃圾收集器3.1. 并行垃圾收集器&#xff08;Parallel Garbage Collector&#xff09;3.2. CMS 垃圾收集器&#xff08;Concurrent Mark-Sweep Garbage Collector&…

情感分析方法與實踐

第1關&#xff1a;情感分析的基本方法 情感分析簡介 情感分析&#xff0c;又稱意見挖掘、傾向性分析等。簡單而言&#xff0c;是對帶有情感色彩的主觀性文本進行分析、處理、歸納和推理的過程。在日常生活中&#xff0c;情感分析的應用非常普遍&#xff0c;下面列舉幾種常見的…

Gradle學習-3 Gradle插件

1、Gredle插件是什么 Gradle插件是用于擴展和增強Gradle構建系統的功能模塊通過插件&#xff0c;Gradle可以執行各種構建任務&#xff0c;如編譯代碼、打包應用、運行測試等 Gradle插件主要分為&#xff1a;二進制插件、腳本插件 二進制插件二進制插件是預編譯的、可以復用的…