


下載本文檔
版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報或認(rèn)領(lǐng)
文檔簡介
c++二分查找?guī)旌瘮?shù)二分查找是一種基于比較的查找算法,它的基本思想是將查詢的關(guān)鍵字與表中間位置的關(guān)鍵字進(jìn)行比較,根據(jù)比較結(jié)果來確定待查關(guān)鍵字在前半部分還是后半部分中進(jìn)行查找,從而在每一個比較的過程中把待查范圍縮小一半。二分查找雖然算法簡單,但是實(shí)現(xiàn)過程還是比較繁瑣的,因此常常使用庫函數(shù)來進(jìn)行快速實(shí)現(xiàn)。
C++標(biāo)準(zhǔn)庫提供了對于二分查找的支持,在<algorithm>頭文件中提供了以下兩個函數(shù):
1.binary_search
binary_search是C++STL中二分查找的核心函數(shù),它的原型如下:
template<classForwardIt,classT>
boolbinary_search(ForwardItfirst,ForwardItlast,constT&value);
binary_search函數(shù)的輸入是迭代器first和last、要查找的值value,函數(shù)返回值為bool類型,表示是否找到待查找的值。需要注意的是,輸入的區(qū)間[first,last)必須按照升序排序,如果不滿足條件,則結(jié)果是undefinedbehavior。
binary_search的實(shí)現(xiàn)原理是不斷地將區(qū)間[first,last)劃分成兩個子區(qū)間,從而逐漸縮小查找范圍,最終找到待查找值,或者將區(qū)間縮小至只有一個元素時退出循環(huán)。
2.lower_bound
lower_bound函數(shù)用于在一個已經(jīng)排好序的序列中查找第一個不小于目標(biāo)值的元素位置,其原型如下:
template<classForwardIt,classT>
ForwardItlower_bound(ForwardItfirst,ForwardItlast,constT&value);
lower_bound函數(shù)的輸入和binary_search類似:迭代器first和last表示待查找元素的范圍、value表示待查找的值。不同的是,lower_bound不僅返回查找結(jié)果是否成功的bool值,還返回查找到的元素的迭代器。
lower_bound的實(shí)現(xiàn)原理和binary_search相似,區(qū)別在于lower_bound首先找到第一個大于等于目標(biāo)值的元素位置,而不是判斷目標(biāo)值是否在序列中。
需要注意的是,binary_search和lower_bound均只適用于有序序列,如果序列無序,則可能返回錯誤結(jié)果。同時,這兩個函數(shù)也是二分查找算法中的特例,可以用更一般的二分查找算法來實(shí)現(xiàn),以適用于更為廣泛的應(yīng)用場景。
總之,二分查找是一種非常實(shí)用的算法,常常應(yīng)用于搜索大規(guī)模數(shù)據(jù)的場景中,例如查找有序數(shù)組中的元素、查找字符串中的某一個字符等等。C++的標(biāo)準(zhǔn)庫中提供了bina
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 二零二五年度教育培訓(xùn)機(jī)構(gòu)教育行業(yè)數(shù)據(jù)服務(wù)協(xié)議
- 二零二五年度農(nóng)業(yè)科技文職人員聘用協(xié)議
- 2025年度茶樓合作經(jīng)營協(xié)議書:茶樓與茶藝茶具研發(fā)中心的合作合同
- 二零二五年度知識產(chǎn)權(quán)質(zhì)押合同解除與資金返還協(xié)議
- 2025年度船舶租賃與船舶技術(shù)咨詢服務(wù)協(xié)議
- 2025年度超市轉(zhuǎn)讓與智能化升級改造合作協(xié)議
- 2025年度智能化社區(qū)物業(yè)委托經(jīng)營管理合同
- 專業(yè)資格教育培訓(xùn)合作協(xié)議
- 新型儲能技術(shù)應(yīng)用開發(fā)合作協(xié)議
- 行路難:古典詩詞中的壯志情懷教案
- 中建住宅樓懸挑卸料平臺專項(xiàng)施工方案
- 【MOOC】數(shù)據(jù)庫系統(tǒng)(下):管理與技術(shù)-哈爾濱工業(yè)大學(xué) 中國大學(xué)慕課MOOC答案
- 日本留學(xué)中介簽約合同
- 鐵路安全應(yīng)急預(yù)案
- 《城市軌道交通車輛構(gòu)造》 課件 2.2 不銹鋼車體結(jié)構(gòu)認(rèn)知
- 古詩詞誦讀《李憑箜篌引》 公開課一等獎創(chuàng)新教案統(tǒng)編版高中語文選擇性必修中冊
- 小學(xué)生日常行為規(guī)范實(shí)施方案
- 2024-2025學(xué)年九年級化學(xué)人教版上冊檢測試卷(1-4單元)
- 2024年遼寧省鞍山岫巖滿族自治縣事業(yè)單位招聘(150人)歷年高頻難、易錯點(diǎn)500題模擬試題附帶答案詳解
- DBJ46-070-2024 海南省民用建筑外門窗工程技術(shù)標(biāo)準(zhǔn)
- 金屬冶煉安全生產(chǎn)實(shí)務(wù)注冊安全工程師考試(初級)試題與參考答案
評論
0/150
提交評論