


下載本文檔
版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡介
c++二分查找?guī)旌瘮?shù)二分查找是一種基于比較的查找算法,它的基本思想是將查詢的關(guān)鍵字與表中間位置的關(guān)鍵字進(jìn)行比較,根據(jù)比較結(jié)果來確定待查關(guān)鍵字在前半部分還是后半部分中進(jìn)行查找,從而在每一個(gè)比較的過程中把待查范圍縮小一半。二分查找雖然算法簡單,但是實(shí)現(xiàn)過程還是比較繁瑣的,因此常常使用庫函數(shù)來進(jìn)行快速實(shí)現(xiàn)。
C++標(biāo)準(zhǔn)庫提供了對于二分查找的支持,在<algorithm>頭文件中提供了以下兩個(gè)函數(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)劃分成兩個(gè)子區(qū)間,從而逐漸縮小查找范圍,最終找到待查找值,或者將區(qū)間縮小至只有一個(gè)元素時(shí)退出循環(huán)。
2.lower_bound
lower_bound函數(shù)用于在一個(gè)已經(jīng)排好序的序列中查找第一個(gè)不小于目標(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首先找到第一個(gè)大于等于目標(biāo)值的元素位置,而不是判斷目標(biāo)值是否在序列中。
需要注意的是,binary_search和lower_bound均只適用于有序序列,如果序列無序,則可能返回錯(cuò)誤結(jié)果。同時(shí),這兩個(gè)函數(shù)也是二分查找算法中的特例,可以用更一般的二分查找算法來實(shí)現(xiàn),以適用于更為廣泛的應(yīng)用場景。
總之,二分查找是一種非常實(shí)用的算法,常常應(yīng)用于搜索大規(guī)模數(shù)據(jù)的場景中,例如查找有序數(shù)組中的元素、查找字符串中的某一個(gè)字符等等。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)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 廣東省實(shí)驗(yàn)中學(xué)廣州市天河區(qū)附屬實(shí)驗(yàn)學(xué)校2021-2022學(xué)年八年級下學(xué)期期中物理試題(含答案)
- 基層中醫(yī)藥知識培訓(xùn)課件
- (一模)哈三中2025屆高三第一次模擬考試 英語試題(含答案)
- 物業(yè)管理服務(wù)委托及管理費(fèi)支付協(xié)議
- 安東尼奇妙的冒險(xiǎn)故事讀后感
- 項(xiàng)目執(zhí)行工作計(jì)劃書與時(shí)間表安排
- 山西省晉中市太谷區(qū)職業(yè)中學(xué)校2024-2025學(xué)年高一上學(xué)期期末考試生物試題
- 企業(yè)文件保密制度表格化處理記錄
- 三農(nóng)問題社會調(diào)查方法與技術(shù)指導(dǎo)書
- 離職員工知識產(chǎn)權(quán)保密協(xié)議
- 標(biāo)識標(biāo)牌制作及安裝項(xiàng)目技術(shù)方案
- 醫(yī)療器械物價(jià)收費(fèi)申請流程
- DB3410T 34-2024特定地域單元生態(tài)產(chǎn)品價(jià)值核算規(guī)范
- 江蘇紅豆實(shí)業(yè)股份有限公司償債能力分析
- 青島中石化輸油管道爆炸事故調(diào)查報(bào)告
- 2024年蘇州職業(yè)大學(xué)高職單招(英語/數(shù)學(xué)/語文)筆試歷年參考題庫含答案解析
- 充電樁采購安裝投標(biāo)方案(技術(shù)方案)
- 教科版小學(xué)科學(xué)六年級下冊單元練習(xí)試題及答案(全冊)
- 《Java程序設(shè)計(jì)》電子課件
- 乳腺癌患者的疼痛護(hù)理課件
- 研課標(biāo)說教材修改版 八年級下冊
評論
0/150
提交評論