二分查找
二分搜尋是一種重複將搜尋空間一分為二的演算法。這種搜尋技術遵循分而治之的策略。每次迭代中搜尋空間總是減少一半。導致時間複雜度為 O(log(n)),其中 n 為元素數。
條件:陣列應該是排序的,但它們也可以應用於單調函數,我們需要找到單調遞增或單調遞減。
當我們需要以對數時間縮小搜尋空間時,它就有效。
我們使用兩個指針,左指針和右指針。取左右的平均值來找出中間元素。
現在,我們根據條件檢查應該將左右指針移到哪裡。
解決一個問題主要需要三個步驟:
- 預處理: 如果輸入未排序,則對輸入進行排序。
- 二分查找:使用兩個指標並找到中間部分來劃分搜尋空間,然後相應地選擇正確的一半。
- 後處理:決定輸出。
二分搜尋演算法的優點 - 對於大數據,二分搜尋比線性搜尋更快,因為它每次將數組切成兩半,而不是逐一檢查每個元素。這使得它更快、更有效率。
限制:二分查找僅適用於已排序的數組,因此對於小型未排序數組效率不高,因為排序需要額外的時間。對於小型記憶體搜索,它的效果也不如線性搜索。
應用: 用於在排序數組中搜尋元素,時間複雜度為 O(log(n)),也可用於尋找數組中的最小或最大元素。
基本二分查找程式碼 -
程式碼
def binarySearch(nums, target): if len(nums) == 0: return -1 left, right = 0, len(nums) - 1 while left right return -1
33。在旋轉排序數組中搜尋
給定可能旋轉後的陣列 nums 和整數目標,如果目標在 nums 中,則傳回目標索引,如果不在 nums 中,則傳回 -1。
您必須編寫一個運行時間複雜度為 O(log n) 的演算法。
範例1:
輸入:nums = [4,5,6,7,0,1,2],目標 = 0
輸出:4
範例2:
輸入:nums = [4,5,6,7,0,1,2],目標 = 3
輸出:-1
範例3:
輸入:nums = [1],目標 = 0
輸出:-1
程式碼
def binarySearch(nums, target): if len(nums) == 0: return -1 left, right = 0, len(nums) - 1 while left right return -1
- 使用左右兩個指針,迭代直到它們重疊。
- 找出中間元素。
- 由於陣列已排序但已旋轉,我們不能簡單地將左側或右側的元素與中間的元素進行比較。
- 首先,透過比較中指標與左指標或右指標來決定左部分或右部分排序。
- 根據這個結論,相應地調整指針。
時間複雜度 - O(log(n)),因為搜尋空間在每次迭代中被分成兩半。
空間複雜度 - O(1)
單調遞增
162。求峰值元素
峰值元素是嚴格大於其鄰居的元素。
給定一個 0 索引的整數數組 nums,找到一個峰值元素,並傳回其索引。如果數組包含多個峰值,則傳回任意峰值的索引。
您可能會想像 nums[-1] = nums[n] = -∞。換句話說,一個元素總是被認為嚴格大於數組外部的鄰居。
您必須編寫一個在 O(log n) 時間內執行的演算法。
範例1:
輸入:nums = [1,2,3,1]
輸出:2
說明:3 是峰值元素,您的函數應傳回索引號 2。
範例2:
輸入:nums = [1,2,1,3,5,6,4]
輸出:5
說明:您的函數可以傳回索引號 1(峰值元素為 2)或索引號 5(峰值元素為 6)。
程式碼
class Solution: def search(self, nums: List[int], target: int) -> int: left = 0 right = len(nums)-1 while left = nums[left]: # if nums[mid]= nums[left]: if nums[left] <ol> <li>在此類問題中,我們需要透過比較中間的左側或右側元素來檢查峰值。 </li> <li>這有助於確定圖表趨勢是向上還是向下。 </li> <li>要找出最大值,請搜尋向上的斜率並探索正確的子空間。 </li> <li>要找出最小值,請搜尋左側子空間</li> </ol> <p><strong>時間複雜度 - O(log(n))</strong>,因為搜尋空間在每次迭代中被分成兩半。 <br> <strong>空間複雜度 - O(1)</strong></p>
以上是二分查找 ||蟒蛇 ||資料結構和演算法的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本文解釋瞭如何使用美麗的湯庫來解析html。 它詳細介紹了常見方法,例如find(),find_all(),select()和get_text(),以用於數據提取,處理不同的HTML結構和錯誤以及替代方案(SEL)

Python的statistics模塊提供強大的數據統計分析功能,幫助我們快速理解數據整體特徵,例如生物統計學和商業分析等領域。無需逐個查看數據點,只需查看均值或方差等統計量,即可發現原始數據中可能被忽略的趨勢和特徵,並更輕鬆、有效地比較大型數據集。 本教程將介紹如何計算平均值和衡量數據集的離散程度。除非另有說明,本模塊中的所有函數都支持使用mean()函數計算平均值,而非簡單的求和平均。 也可使用浮點數。 import random import statistics from fracti

本文比較了Tensorflow和Pytorch的深度學習。 它詳細介紹了所涉及的步驟:數據準備,模型構建,培訓,評估和部署。 框架之間的關鍵差異,特別是關於計算刻度的

Python 對象的序列化和反序列化是任何非平凡程序的關鍵方面。如果您將某些內容保存到 Python 文件中,如果您讀取配置文件,或者如果您響應 HTTP 請求,您都會進行對象序列化和反序列化。 從某種意義上說,序列化和反序列化是世界上最無聊的事情。誰會在乎所有這些格式和協議?您想持久化或流式傳輸一些 Python 對象,並在以後完整地取回它們。 這是一種在概念層面上看待世界的好方法。但是,在實際層面上,您選擇的序列化方案、格式或協議可能會決定程序運行的速度、安全性、維護狀態的自由度以及與其他系

Linux終端中查看Python版本時遇到權限問題的解決方法當你在Linux終端中嘗試查看Python的版本時,輸入python...

該教程建立在先前對美麗湯的介紹基礎上,重點是簡單的樹導航之外的DOM操縱。 我們將探索有效的搜索方法和技術,以修改HTML結構。 一種常見的DOM搜索方法是EX

本文討論了諸如Numpy,Pandas,Matplotlib,Scikit-Learn,Tensorflow,Tensorflow,Django,Blask和請求等流行的Python庫,並詳細介紹了它們在科學計算,數據分析,可視化,機器學習,網絡開發和H中的用途

本文指導Python開發人員構建命令行界面(CLIS)。 它使用Typer,Click和ArgParse等庫詳細介紹,強調輸入/輸出處理,並促進用戶友好的設計模式,以提高CLI可用性。


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

MinGW - Minimalist GNU for Windows
這個專案正在遷移到osdn.net/projects/mingw的過程中,你可以繼續在那裡關注我們。 MinGW:GNU編譯器集合(GCC)的本機Windows移植版本,可自由分發的導入函式庫和用於建置本機Windows應用程式的頭檔;包括對MSVC執行時間的擴展,以支援C99功能。 MinGW的所有軟體都可以在64位元Windows平台上運作。

DVWA
Damn Vulnerable Web App (DVWA) 是一個PHP/MySQL的Web應用程序,非常容易受到攻擊。它的主要目標是成為安全專業人員在合法環境中測試自己的技能和工具的輔助工具,幫助Web開發人員更好地理解保護網路應用程式的過程,並幫助教師/學生在課堂環境中教授/學習Web應用程式安全性。 DVWA的目標是透過簡單直接的介面練習一些最常見的Web漏洞,難度各不相同。請注意,該軟體中

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

Atom編輯器mac版下載
最受歡迎的的開源編輯器