5.算法講解之-二分查找(簡單易懂)

1.簡介

????????1.二分查找的思路簡單易懂,較難的是如何處理查找過程中的邊界條件,當較長時間沒寫二分查找的時候就容易忘記如何處理邊界條件。

? ? ? ? 2.只有多寫代碼,多做筆記就不易忘記邊界條件

2.算法思路

? ? ? ? 正常查找都是從頭到尾查找一個數字是否在數組中

? ? ? ? 二分查找適用于已經有序的數組,利用有序的這個性質,定義兩個指針,left指向頭,right指向尾,定義一個mid為頭尾指針的平均值。

首先選擇mid位置的數字和目標值比較

中間值與target相等直接返回這個數字的下標即可

如果不相等

????????如果mid位置的數字數字大于目標值,則mid位置的數字向右所有數字都大于target,全部排除,讓mid-1變為新的尾部

????????如果mid位置的數字數字小于目標值,則mid位置的數字向左所有數字都小于target,全部排除,讓mid+1成為新的頭部

最后left>right的話說明該數組中沒有target這個數字

? ? 示例

????????給定一個?n?個元素有序的(升序)整型數組?nums?和一個目標值?target??,寫一個函數搜索?nums?中的?target,如果目標值存在返回下標,否則返回?-1

? ? ? ?

????????示例1

? ? ? ? ?nums=[-1,0,3,5,9,] target=9? ? ? ? 輸出4,因為數組中有9,且其下標尾4

下面給出查找的過程

mid處為3,3<9,所以讓mid+1成為新的頭部(left=mid+ 1)

如下圖

5<9,再次縮小左邊界

找到了,返回mid下標4

? ? ? ? 示例2? ? ? ?

????????nums=[-1,0,3,5,9,] target=2? ? ? ? 輸出-1,因為數組中沒有2

同理給出過程

3>2,縮小右邊界 right=mid-1

此時,新的mid為(0+1)/2=0

-1<2,讓left=mid+1

此時0<2,讓left=mid+1

left>right.說明整個數組中沒有目標值,返回-1

3.實現代碼

代碼如下

int BinarySearch(vector<int>& arr, int target)
{if (arr.size() < 1)return -1;int left = 0, right =arr.size() - 1;while (left <= right){int mid = left + ((right - left) >> 1);if (arr[mid] > target)right = mid - 1;else if (arr[mid] < target)left = mid + 1;elsereturn mid;}//沒找到return -1;
}

4.二分查找的特點

時間復雜度:O(logN)

空間復雜度:O(1)

適用于查找有序的數組

5.簡單測試

測試代碼

int BinarySearch(vector<int>& arr, int target)
{if (arr.size() < 1)return -1;int left = 0, right =arr.size() - 1;while (left <= right){int mid = left + ((right - left) >> 1);if (arr[mid] > target)right = mid - 1;else if (arr[mid] < target)left = mid + 1;elsereturn mid;}//沒找到return -1;
}int main()
{vector<int> arr = { -1,0,3,5,9 };cout << BinarySearch(arr, 9) << endl;cout << BinarySearch(arr, 2) << endl;return 0;
}

測試結果

6.Leetcode相關練習題

704. 二分查找 - 力扣(LeetCode)

35. 搜索插入位置 - 力扣(LeetCode)

367. 有效的完全平方數 - 力扣(LeetCode)

69. x 的平方根 - 力扣(LeetCode)

34. 在排序數組中查找元素的第一個和最后一個位置 - 力扣(LeetCode)

下面這道題思想類似于二分查找,是高頻面試題之一

240. 搜索二維矩陣 II - 力扣(LeetCode)

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

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

相關文章

使用pycharm+opencv進行視頻抽幀(可以用來擴充數據集)+ labelimg的使用(數據標準)

一.視頻抽幀 1.新創建一個空Pycharm項目文件&#xff0c;命名為streach zhen 注&#xff1a;然后要做一個前期工作 創建opencv環境 &#xff08;1&#xff09;我們在這個pycharm項目的終端里面輸入下面的命令&#xff1a; pip install opencv-python --user -i https://pypi.t…

SettingWithCopyWarning: A value is trying to be set on a copy of a slice fro

SettingWithCopyWarning: A value is trying to be set on a copy of a slice fro 錯誤代碼&#xff1a; while i < len(data_csv_data):if data_csv_data[flowmember][i] j:data_csv_data[label][i] data_csv_label[label][j-1]data_csv_data[classes][i]data_csv_label[…

[數據集][目標檢測]獼猴桃檢測數據集VOC+YOLO格式1838張1類別

數據集格式&#xff1a;Pascal VOC格式YOLO格式(不包含分割路徑的txt文件&#xff0c;僅僅包含jpg圖片以及對應的VOC格式xml文件和yolo格式txt文件) 圖片數量(jpg文件個數)&#xff1a;1838 標注數量(xml文件個數)&#xff1a;1838 標注數量(txt文件個數)&#xff1a;1838 標注…

企業級寬表建設

1 寬表概述 寬表&#xff0c;從字面意義上講就是字段比較多的數據庫表&#xff0c;通常情況下是講很多相關的數據&#xff0c;包括實時表、維度表、指標等格言錄在一起形成的一張數據表。 2 寬表的優點 2.1 開發效率提升 由于把不同的信息放在同一張表存儲&#xff0c;寬表…

sensitive-word 敏感詞 v0.17.0 新特性之 IPV4 檢測

敏感詞系列 sensitive-word-admin 敏感詞控臺 v1.2.0 版本開源 sensitive-word-admin v1.3.0 發布 如何支持分布式部署&#xff1f; 01-開源敏感詞工具入門使用 02-如何實現一個敏感詞工具&#xff1f;違禁詞實現思路梳理 03-敏感詞之 StopWord 停止詞優化與特殊符號 04-…

詳解 Spark 核心編程之 RDD 持久化

一、問題引出 /** 案例&#xff1a;對同一份數據文件分別做 WordCount 聚合操作和 Word 分組操作 期望&#xff1a;針對數據文件只進行一次分詞、轉換操作得到 RDD 對象&#xff0c;然后再對該對象分別進行聚合和分組&#xff0c;實現數據重用 */ object TestRDDPersist {def …

Jupyter Notebook快速搭建

Jupyter Notebook why Jupyter Notebook Jupyter Notebook 是一個開源的 Web 應用程序&#xff0c;允許你創建和分享包含實時代碼、方程、可視化和解釋性文本的文檔。其應用包括&#xff1a;數據清洗和轉換、數值模擬、統計建模、數據可視化、機器學習等等。 Jupyter Notebo…

東芝機械人電池低報警解除與機器人多旋轉數據清零

今天啟動一臺設備,觸摸屏一直顯示機器人報警(翻譯過后為電池電量低),更換電池后關機重啟后也不能消除,所以打開示教器,下面就來說說怎么解決此項問題(可以參考官方發的手冊,已手冊為主)。 一,設備 下面來看看機械手的照片與示教器的照片 四軸機械手(六軸機器人有可…

可視化大屏也在卷組件化設計了?分享一些可視化組件

hello&#xff0c;我是大千UI工場&#xff0c;這次分享一些可視化大屏的組件&#xff0c;供大家欣賞。&#xff08;本人沒有源文件提供&#xff09;

動態內存基礎實踐

文章目錄 1.new 創建堆內存對象2.delete釋放內存空間3.malloc申請內存4.free釋放malloc申請的內存空間 1.new 創建堆內存對象 2.delete釋放內存空間 3.malloc申請內存 4.free釋放malloc申請的內存空間 #include <iostream> #include <string>using namespace s…

基礎數學內容重構(后綴0個數)

今天也是參加了一下寧波大學的校賽&#xff0c;其中有一道題是求后綴0的個數&#xff0c;題意是讓我們求一下式子的后綴0個數&#xff1a; 看上去比較復雜&#xff0c;但是通過化簡我們可以知道以上式子就是求&#xff08;n 1&#xff09;&#xff01;&#xff0c;這里化簡的過…

用貪心算法計算十進制數轉二進制數(小數部分)

在上一篇博文用貪心算法計算十進制數轉二進制數&#xff08;整數部分&#xff09;-CSDN博客中&#xff0c;小編介紹了用貪心算法進行十進制整數轉化為二進制數的操作步驟&#xff0c;那么有朋友問我&#xff0c;那十進制小數轉二進制&#xff0c;可以用貪心算法來計算嗎&#x…

[C++]vector的模擬實現

下面是簡單的實現vector的功能&#xff0c;沒有涉及使用內存池等復雜算法來提高效率。 一、vector的概述 &#xff08;一&#xff09;、抽象數據類型定義 容器&#xff1a;向量&#xff08;vector&#xff09;vector是表示大小可以變化的數組的序列容器。像數組一樣&#xf…

帶你學習Mybatis之Mybatis映射文件

Mybatis映射文件 增刪改查 簡單地增刪改查 <select id"selectUser" resultType"User"> select * from user where id #{id}</select><insert id"addUser"> insert into user (name,account) values (#{name},#{account…

[sylar]后端學習:配置環境(一)

1.介紹 基于sylar大神的C高性能后端網絡框架來進行環境配置和后續學習。網站鏈接&#xff1a;sylar的Linux環境配置 2.下載 按照視頻進行下載&#xff0c;并進行下載&#xff0c;并最好還要下載一個vssh的軟件。可以直接在網上搜索即可。 sylar_環境配置&#xff0c;vssh下…

CentOS 運維常用的shell腳本

文章目錄 一、操作系統磁盤空間查看實時獲取系統運行狀態獲取cpu、內存等系統運行狀態獲取系統信息二、應用程序獲取進程運行狀態查看有多少遠程的 IP 在連接本機三、用戶管理統計當前 Linux 系統中可以登錄計算機的賬戶有多少個創建用戶四、自動化管理自動備份日志文件監控的頁…

MySQL常見操作

MySQL字符串連接 在MySQL中&#xff0c;字符串連接可以使用CONCAT()函數或雙豎線||操作符進行。下面是兩種方法的示例&#xff1a; 使用CONCAT()函數&#xff1a; CONCAT(,2001,, ABC)使用雙豎線||操作符&#xff1a; ,2001, || ABC您可以根據自己的偏好選擇其中一種方法來…

TS38.300中的切換流程(很一般)

本文根據3GPP R18 TS 38.300第9.2.3節整理 切換(Handover)是移動終端(UE)進入RRC_CONNECTED狀態后在不同服務小區(Cell)之間保持與網絡聯系唯一手段&#xff0c;期間首先通過控制面(C-Plane)進行無線測量、切換協商及觸發等&#xff1b;為此3GPP在TS38.300中定義如下。 RAN系統…

shardingsphere5 自定義分片(sharding-algorithm)算法

背景 在做分表時&#xff0c;需要自定義算法。 這里實現的算法是&#xff1a; 分表字段的 hashCode 取余。 算法 public class UserShardingAlgorithm implements StandardShardingAlgorithm<String> {public static String type "USER_SHARDING_STRATEGY"…

2024KCon大會議題招募火熱進行中

歷時1個多月我們收到了來自全國各地小伙伴們的議題投遞既有前瞻性的技術研判亦有安全領域的最新策略......感謝每一位對KCon大會傾注熱情與支持的你&#xff01; 我們也收到了不少小伙伴的私信&#xff0c;有的因為工作繁忙有的因為在緊張備戰2024網絡安全攻防演練表示原定的時…