久久精品国产亚洲高清|精品日韩中文乱码在线|亚洲va中文字幕无码久|伊人久久综合狼伊人久久|亚洲不卡av不卡一区二区|精品久久久久久久蜜臀AV|国产精品19久久久久久不卡|国产男女猛烈视频在线观看麻豆

千鋒教育-做有情懷、有良心、有品質(zhì)的職業(yè)教育機(jī)構(gòu)

手機(jī)站
千鋒教育

千鋒學(xué)習(xí)站 | 隨時(shí)隨地免費(fèi)學(xué)

千鋒教育

掃一掃進(jìn)入千鋒手機(jī)站

領(lǐng)取全套視頻
千鋒教育

關(guān)注千鋒學(xué)習(xí)站小程序
隨時(shí)隨地免費(fèi)學(xué)習(xí)課程

當(dāng)前位置:首頁  >  技術(shù)干貨  > Python數(shù)據(jù)結(jié)構(gòu)的時(shí)間復(fù)雜性

Python數(shù)據(jù)結(jié)構(gòu)的時(shí)間復(fù)雜性

來源:千鋒教育
發(fā)布人:xqq
時(shí)間: 2023-11-07 05:45:56 1699307156

1.讓我們了解大O符號的含義是什么?

在算法中執(zhí)行許多操作。這些操作可能包括遍歷集合,復(fù)制項(xiàng)目或整個(gè)集合,將項(xiàng)目追加到集合中,在集合的開始或結(jié)尾處插入項(xiàng)目,刪除項(xiàng)目或更新集合中的項(xiàng)目。

Big-O衡量算法運(yùn)算的時(shí)間復(fù)雜度。它測量算法計(jì)算所需運(yùn)算所需的時(shí)間。盡管我們也可以測量空間復(fù)雜度(算法占用多少空間),但本文將重點(diǎn)介紹時(shí)間復(fù)雜度。

用最簡單的術(shù)語來說,BigO表示法是一種基于輸入大小(稱為n)來衡量操作性能的方法。

2.BigO表示法有何不同?

我們需要熟悉許多常見的BigO符號。

讓我們考慮n為輸入集合的大小。就時(shí)間復(fù)雜度而言:

O(1):無論您的集合有多大,執(zhí)行操作所花費(fèi)的時(shí)間都是恒定的。這是恒定的時(shí)間復(fù)雜度符號。這些操作盡可能快。例如,檢查集合內(nèi)部是否有任何項(xiàng)目的操作是O(1)操作。

O(logn):當(dāng)集合的大小增加時(shí),執(zhí)行操作所花費(fèi)的時(shí)間對數(shù)增加。這是對數(shù)時(shí)間復(fù)雜度表示法。潛在優(yōu)化的搜索算法為O(logn)。

O(n):執(zhí)行操作所需的時(shí)間與集合中的項(xiàng)目數(shù)成線性正比。這是線性時(shí)間復(fù)雜度符號。就性能而言,這介于兩者之間或中等。作為一個(gè)實(shí)例,如果我們想對一個(gè)集合中的所有項(xiàng)目求和,那么我們將不得不遍歷該集合。因此,集合的迭代是O(n)操作。

(nlogn):執(zhí)行某項(xiàng)操作的性能是集合中項(xiàng)目數(shù)量的擬線性函數(shù)。這稱為準(zhǔn)線性時(shí)間復(fù)雜度表示法。優(yōu)化排序算法的時(shí)間復(fù)雜度通常為n(logn)。

O(n平方):執(zhí)行操作所需的時(shí)間與集合中項(xiàng)目的平方成正比。這稱為二次時(shí)間復(fù)雜度表示法。

(n!):當(dāng)在操作中計(jì)算集合的每個(gè)單個(gè)排列時(shí),因此執(zhí)行操作所需的時(shí)間取決于集合中項(xiàng)目的大小。這稱為階乘時(shí)間復(fù)雜度表示法。非常慢。

該圖像概述了Big-O符號。

O(1)很快。O(n平方)很慢。O(n!)非常慢。

大O符號是相對的。大O表示法與機(jī)器無關(guān),忽略常量,并且被包括數(shù)學(xué)家,技術(shù)人員,數(shù)據(jù)科學(xué)家等在內(nèi)的廣泛讀者所理解。

最佳,平均,最差情況

當(dāng)我們計(jì)算操作的時(shí)間復(fù)雜度時(shí),我們可以根據(jù)最佳,平均或最壞情況產(chǎn)生復(fù)雜度。

最佳情況方案:顧名思義,這是當(dāng)數(shù)據(jù)結(jié)構(gòu)和集合中的項(xiàng)目以及參數(shù)處于最佳狀態(tài)時(shí)的方案。例如,假設(shè)我們要在集合中找到一個(gè)項(xiàng)目。如果該項(xiàng)目恰好是集合的第一項(xiàng),那么這是該操作的最佳情況。

平均情況是根據(jù)輸入值的分布定義復(fù)雜度。

最壞的情況是可能需要一種操作,該操作需要在大型集合(例如列表)中找到位于最后一個(gè)項(xiàng)目的項(xiàng)目,并且算法會從第一個(gè)項(xiàng)目開始對集合進(jìn)行迭代。

以上內(nèi)容為大家介紹了Python數(shù)據(jù)結(jié)構(gòu)的時(shí)間復(fù)雜性,希望對大家有所幫助,如果想要了解更多Python相關(guān)知識,請關(guān)注IT培訓(xùn)機(jī)構(gòu):千鋒教育。http://m.2667701.com/

聲明:本站稿件版權(quán)均屬千鋒教育所有,未經(jīng)許可不得擅自轉(zhuǎn)載。
10年以上業(yè)內(nèi)強(qiáng)師集結(jié),手把手帶你蛻變精英
請您保持通訊暢通,專屬學(xué)習(xí)老師24小時(shí)內(nèi)將與您1V1溝通
免費(fèi)領(lǐng)取
今日已有369人領(lǐng)取成功
劉同學(xué) 138****2860 剛剛成功領(lǐng)取
王同學(xué) 131****2015 剛剛成功領(lǐng)取
張同學(xué) 133****4652 剛剛成功領(lǐng)取
李同學(xué) 135****8607 剛剛成功領(lǐng)取
楊同學(xué) 132****5667 剛剛成功領(lǐng)取
岳同學(xué) 134****6652 剛剛成功領(lǐng)取
梁同學(xué) 157****2950 剛剛成功領(lǐng)取
劉同學(xué) 189****1015 剛剛成功領(lǐng)取
張同學(xué) 155****4678 剛剛成功領(lǐng)取
鄒同學(xué) 139****2907 剛剛成功領(lǐng)取
董同學(xué) 138****2867 剛剛成功領(lǐng)取
周同學(xué) 136****3602 剛剛成功領(lǐng)取
相關(guān)推薦HOT
python隊(duì)列Queue

QueueQueue是python標(biāo)準(zhǔn)庫中的線程安全的隊(duì)列(FIFO)實(shí)現(xiàn),提供了一個(gè)適用于多線程編程的先進(jìn)先出的數(shù)據(jù)結(jié)構(gòu),即隊(duì)列,用來在生產(chǎn)者和消費(fèi)者線程...詳情>>

2023-11-07 08:24:21
Python和PHP的區(qū)別

從開發(fā)的角度來看,PHP是面向WEB的語言。PHP應(yīng)用程序更像是一組單獨(dú)的腳本,甚至只是一個(gè)單獨(dú)入口。而Python是多用途語言,也可以用于WEB開發(fā),...詳情>>

2023-11-07 08:02:45
Python爬蟲原理

簡單來說互聯(lián)網(wǎng)是由一個(gè)個(gè)站點(diǎn)和網(wǎng)絡(luò)設(shè)備組成的大網(wǎng),我們通過瀏覽器訪問站點(diǎn),站點(diǎn)把HTML、JS、CSS代碼返回給瀏覽器,這些代碼經(jīng)過瀏覽器解析...詳情>>

2023-11-07 07:33:56
使用Cython為Python編寫更快的C擴(kuò)展

使用Python很有趣,但有時(shí),用它編寫的程序可能很慢。所有的運(yùn)行時(shí)動態(tài)調(diào)度會帶來很大的代價(jià):有時(shí)它比用C或Rust等系統(tǒng)語言編寫的等效代碼慢10...詳情>>

2023-11-07 07:23:08
Python字符串連接

字符串是Python中常用的數(shù)據(jù)類型,在開發(fā)過程中可以對字符創(chuàng)進(jìn)行截取并與其他字符創(chuàng)進(jìn)行連接。下面小編整理了5種方法完成Python字符創(chuàng)的連接!加...詳情>>

2023-11-07 06:47:08