中文亚洲精品无码_熟女乱子伦免费_人人超碰人人爱国产_亚洲熟妇女综合网

當(dāng)前位置: 首頁 > news >正文

網(wǎng)站平臺(tái)建設(shè)招標(biāo)書百度seo優(yōu)化服務(wù)項(xiàng)目

網(wǎng)站平臺(tái)建設(shè)招標(biāo)書,百度seo優(yōu)化服務(wù)項(xiàng)目,wordpress 多夢(mèng),網(wǎng)站設(shè)計(jì)費(fèi)用明細(xì)?作者簡(jiǎn)介:人工智能專業(yè)本科在讀,喜歡計(jì)算機(jī)與編程,寫博客記錄自己的學(xué)習(xí)歷程。 🍎個(gè)人主頁:小嗷犬的個(gè)人主頁 🍊個(gè)人網(wǎng)站:小嗷犬的技術(shù)小站 🥭個(gè)人信條:為天地立心&…

?作者簡(jiǎn)介:人工智能專業(yè)本科在讀,喜歡計(jì)算機(jī)與編程,寫博客記錄自己的學(xué)習(xí)歷程。
🍎個(gè)人主頁:小嗷犬的個(gè)人主頁
🍊個(gè)人網(wǎng)站:小嗷犬的技術(shù)小站
🥭個(gè)人信條:為天地立心,為生民立命,為往圣繼絕學(xué),為萬世開太平。


本文目錄

  • 簡(jiǎn)介
  • bisect 庫的使用
    • bisect_left
    • bisect_right
    • insort_left
    • insort_right
  • 二分查找基礎(chǔ)實(shí)現(xiàn)


簡(jiǎn)介

bisect 庫是 Python 標(biāo)準(zhǔn)庫中的一部分,它提供了二分查找的功能。二分查找是一種在有序列表中查找某一特定元素的搜索算法。它的時(shí)間復(fù)雜度為 O(log?n)O(\log n)O(logn),比順序查找的時(shí)間復(fù)雜度 O(n)O(n)O(n) 要有效率。

bisect 庫的使用

bisect 庫提供了 bisect_leftbisect_right、insort_leftinsort_right四個(gè)函數(shù),用于在有序列表中查找或插入元素。

bisect_left

bisect_left 函數(shù)用于在有序列表中二分查找某一位置,使得在該位置插入指定元素后仍保持有序,返回該位置,如果元素已經(jīng)存在,則返回它的左邊位置。

函數(shù)原型如下:

bisect.bisect_left(a, x, lo=0, hi=len(a), *, key=None)

其中,a 是一個(gè)有序列表,x 是要查找的元素,lohi 是查找范圍的左右邊界,key 是一個(gè)函數(shù),用于從列表中提取比較的鍵值。

示例:

# 導(dǎo)入 bisect 庫
import bisect
# 有序列表
a = [1, 2, 3, 3, 5, 6, 6, 6, 8, 10]
# 查找元素 4 的位置
print(bisect.bisect_left(a, 4))  # 4
# 查找元素 6 的位置
print(bisect.bisect_left(a, 6))  # 5

bisect_right

bisect_right 函數(shù)用于在有序列表中二分查找某一位置,使得在該位置插入指定元素后仍保持有序,返回該位置,如果元素已經(jīng)存在,則返回它的右邊位置。

函數(shù)原型如下:

bisect.bisect_right(a, x, lo=0, hi=len(a), *, key=None)

其中,a 是一個(gè)有序列表,x 是要查找的元素,lohi 是查找范圍的左右邊界,key 是一個(gè)函數(shù),用于從列表中提取比較的鍵值。

示例:

# 導(dǎo)入 bisect 庫
import bisect
# 有序列表
a = [1, 2, 3, 3, 5, 6, 6, 6, 8, 10]
# 查找元素 4 的位置
print(bisect.bisect_right(a, 4))  # 4
# 查找元素 6 的位置
print(bisect.bisect_right(a, 6))  # 8

除此之外,bisect_right 還可以簡(jiǎn)寫為 bisect

# 導(dǎo)入 bisect 庫
import bisect
# 有序列表
a = [1, 2, 3, 3, 5, 6, 6, 6, 8, 10]
# 查找元素 4 的位置
print(bisect.bisect(a, 4))  # 4
# 查找元素 6 的位置
print(bisect.bisect(a, 6))  # 8

insort_left

insort_left 函數(shù)用于在有序列表中二分查找某一位置,使得在該位置插入指定元素后仍保持有序,然后將元素插入該位置,如果元素已經(jīng)存在,則插入到它的左邊位置。

函數(shù)原型如下:

bisect.insort_left(a, x, lo=0, hi=len(a), *, key=None)

其中,a 是一個(gè)有序列表,x 是要插入的元素,lohi 是查找范圍的左右邊界,key 是一個(gè)函數(shù),用于從列表中提取比較的鍵值。

示例:

# 導(dǎo)入 bisect 庫
import bisect
# 有序列表
a = [1, 2, 3, 3, 5, 6, 6, 6, 8, 10]
# 插入元素 4
bisect.insort_left(a, 4)
print(a)  # [1, 2, 3, 3, 4, 5, 6, 6, 6, 8, 10]
# 插入元素 6
bisect.insort_left(a, 6)
print(a)  # [1, 2, 3, 3, 4, 5, 6, 6, 6, 6, 8, 10]

insort_right

insort_right 函數(shù)用于在有序列表中二分查找某一位置,使得在該位置插入指定元素后仍保持有序,然后將元素插入該位置,如果元素已經(jīng)存在,則插入到它的右邊位置。

函數(shù)原型如下:

bisect.insort_right(a, x, lo=0, hi=len(a), *, key=None)

其中,a 是一個(gè)有序列表,x 是要插入的元素,lohi 是查找范圍的左右邊界,key 是一個(gè)函數(shù),用于從列表中提取比較的鍵值。

示例:

# 導(dǎo)入 bisect 庫
import bisect
# 有序列表
a = [1, 2, 3, 3, 5, 6, 6, 6, 8, 10]
# 插入元素 4
bisect.insort_right(a, 4)
print(a)  # [1, 2, 3, 3, 4, 5, 6, 6, 6, 8, 10]
# 插入元素 6
bisect.insort_right(a, 6)
print(a)  # [1, 2, 3, 3, 4, 5, 6, 6, 6, 6, 8, 10]

除此之外,insort_right 還可以簡(jiǎn)寫為 insort

# 導(dǎo)入 bisect 庫
import bisect
# 有序列表
a = [1, 2, 3, 3, 5, 6, 6, 6, 8, 10]
# 插入元素 4
bisect.insort(a, 4)
print(a)  # [1, 2, 3, 3, 4, 5, 6, 6, 6, 8, 10]
# 插入元素 6
bisect.insort(a, 6)
print(a)  # [1, 2, 3, 3, 4, 5, 6, 6, 6, 6, 8, 10]

insort 函數(shù)的實(shí)質(zhì)是調(diào)用 bisect 函數(shù)獲取插入位置,然后調(diào)用 list.insert 函數(shù)將元素插入到該位置。

二分查找基礎(chǔ)實(shí)現(xiàn)

在 Python 中,我們可以使用 bisect 庫來實(shí)現(xiàn)二分查找,但其只能根據(jù)元素的值和元素之間的比較關(guān)系來查找元素的位置,如果要根據(jù)元素的其他屬性或其他關(guān)系來查找元素的位置,就需要自己實(shí)現(xiàn)二分查找了。

二分查找的基本模板如下:

def binary_search(nums, target):left, right = 0, len(nums) - 1while left <= right:mid = (left + right) // 2if nums[mid] == target:return midelif nums[mid] < target:left = mid + 1else:right = mid - 1return -1

通過修改模板,我們可以根據(jù)更復(fù)雜的關(guān)系來查找元素。

示例:

852. 山脈數(shù)組的峰頂索引
符合下列屬性的數(shù)組 arr 稱為 山脈數(shù)組

  • arr.length >= 3
  • 存在 i0 < i?< arr.length - 1)使得:
    • arr[0] < arr[1] < ... arr[i-1] < arr[i]
    • arr[i] > arr[i+1] > ... > arr[arr.length - 1]

給你由整數(shù)組成的山脈數(shù)組 arr ,返回任何滿足 arr[0] < arr[1] < ... arr[i - 1] < arr[i] > arr[i + 1] > ... > arr[arr.length - 1] 的下標(biāo) i 。

來源:力扣(LeetCode)
鏈接:https://leetcode.cn/problems/peak-index-in-a-mountain-array

class Solution:def peakIndexInMountainArray(self, arr: List[int]) -> int:n = len(arr)left, right, ans = 1, n - 2, 0while left <= right:mid = (left + right) // 2if arr[mid] > arr[mid + 1]:ans = midright = mid - 1else:left = mid + 1return ans
http://www.risenshineclean.com/news/7505.html

相關(guān)文章:

  • 廣東省建設(shè)執(zhí)業(yè)資格注冊(cè)中心官方網(wǎng)站百度新聞?lì)^條
  • 網(wǎng)站免費(fèi)虛擬主機(jī)申請(qǐng)外貿(mào)seo優(yōu)化公司
  • 溫州龍灣做網(wǎng)站河北seo推廣
  • 濰坊市建設(shè)監(jiān)理協(xié)會(huì)網(wǎng)站第三方推廣平臺(tái)
  • 怎樣做網(wǎng)站管理怎樣在百度上做廣告
  • 做網(wǎng)站要法人身份證嗎品牌營(yíng)銷案例分析
  • 網(wǎng)站添加二維碼百度貼吧網(wǎng)頁版登錄
  • 專業(yè)網(wǎng)站建設(shè)費(fèi)用怎么算怎么做一個(gè)自己的網(wǎng)站
  • 高端企業(yè)網(wǎng)站建設(shè)的核心是什么昆明seo工資
  • 浦城縣規(guī)劃建設(shè)旅游局網(wǎng)站中國(guó)新聞最新消息
  • 百度做網(wǎng)站的公司推廣學(xué)院seo教程
  • 2018做網(wǎng)站的軟件網(wǎng)絡(luò)營(yíng)銷策劃書800字
  • 大同市建設(shè)工程招標(biāo)投標(biāo)網(wǎng)站b2b電商平臺(tái)
  • 酒泉網(wǎng)站建設(shè)與制作企業(yè)推廣平臺(tái)有哪些
  • 佛山網(wǎng)站優(yōu)化指導(dǎo)百度趨勢(shì)搜索
  • 如何做好網(wǎng)站建設(shè)亞馬遜seo關(guān)鍵詞優(yōu)化軟件
  • 電商運(yùn)營(yíng)主要是做什么seo關(guān)鍵詞是怎么優(yōu)化的
  • 政府網(wǎng)站建設(shè)的總結(jié)東莞企業(yè)網(wǎng)站模板建站
  • flash網(wǎng)站項(xiàng)目背景網(wǎng)絡(luò)公司主要做哪些
  • 建設(shè)網(wǎng)站有哪些術(shù)語百度信息流投放
  • 兼職做Ppt代抄論文的網(wǎng)站韶關(guān)今日頭條新聞
  • wordpress如何修改html搜索引擎優(yōu)化的主要手段
  • 網(wǎng)站seo源碼網(wǎng)絡(luò)營(yíng)銷師工作內(nèi)容
  • 華為云自助建站好不好百度一下你就知道啦
  • 怎么做蘋果手機(jī)網(wǎng)站首頁網(wǎng)絡(luò)運(yùn)營(yíng)推廣
  • 河北建設(shè)網(wǎng)站企業(yè)鎖在哪下載剛剛地震最新消息今天
  • 洛陽外貿(mào)網(wǎng)站推廣網(wǎng)站內(nèi)部鏈接優(yōu)化方法
  • 濟(jì)南建設(shè)廳官方網(wǎng)站企業(yè)網(wǎng)絡(luò)營(yíng)銷方案設(shè)計(jì)
  • 唐山中企動(dòng)力做網(wǎng)站搜索大全引擎入口
  • 怎么看網(wǎng)站空間多大品牌整合營(yíng)銷方案