時間 空間複雜度

2021-10-01 04:49:27 字數 1662 閱讀 7111

o(1)解析

o(1)就是最低的時空複雜度了,也就是耗時/耗空間與輸入資料大小無關,無論輸入資料增大多少倍,耗時/耗空間都不變。 雜湊演算法就是典型的o(1)時間複雜度,無論資料規模多大,都可以在一次計算後找到目標(不考慮衝突的話),衝突的話很麻煩的,指向的value會做二次hash到另外一快儲存區域。

通俗易懂的例子

什麼是o(1)呢,就比如你是乙個酒店的管理員,你負責管理酒店的鑰匙,你很聰明,你把酒店的100把鑰匙放在了100個格仔裡面存著,並且把格仔從1~100進行了編號,有一天有客人來了,酒店老闆說,給我拿10號房間的鑰匙給我,你迅速從10號格仔裡面拿出鑰匙給老闆,速度非常快,這時候你就是乙個電腦了,老闆跟你說拿幾號房房間的鑰匙,你只需要看一眼就能知道鑰匙在**。

o(n)解析

比如時間複雜度為o(n),就代表資料量增大幾倍,耗時也增大幾倍。

比如常見的遍歷演算法。 

要找到乙個陣列裡面最大的乙個數,你要把n個變數都掃瞄一遍,操作次數為n,那麼演算法複雜度是o(n).

通俗易懂的例子

突然,有一天,你的老闆給你說,你用100個箱子存100把鑰匙,太浪費空間了,你能補能把鑰匙上編號一下,然後把鑰匙要用繩子穿起來,這樣我們可以把這個放箱子的地方再裝修乙個房間出來。你想了一下,是啊,現在房價這麼貴,這樣能多賺點錢。所以你就不能通過上面的方法來找到鑰匙了,老闆跟你說,給我拿45號房間的鑰匙出來,你就需要從100個鑰匙裡面挨個找45個房間的鑰匙。

o(n^2) 解析

再比如時間複雜度o(n^2),就代表資料量增大n倍時,耗時增大n的平方倍,這是比線性更高的時間複雜度。比如氣泡排序,就是典型的o(n^2)的演算法,對n個數排序,需要掃瞄n×n次。 

用氣泡排序排乙個陣列,對於n個變數的陣列,需要交換變數位置次,那麼演算法複雜度就是o().

通俗易懂的例子

隨著經濟發展越來越好,你的老闆把酒店擴大了,有100層每一層有100個房間,當然,你還是你,不過你因為關注我的部落格,知道怎麼把鑰匙排序更好了,你把每一層的鑰匙穿在一起,然後一共就有100個用繩子穿起來的鑰匙串。然後老闆叫你找鑰匙的時候,你先要找到樓層的編號,再對應找到房間的編號,所以大概對應的是這樣的**。

o(log n)解析

再比如o(log n),當資料增大n倍時,耗時增大log n倍(這裡的log是以2為底的,比如,當資料增大256倍時,耗時只增大8倍,是比線性還要低的時間複雜度)。二分查詢就是o(log n)的演算法,每找一次排除一半的可能,256個資料中查詢只要找8次就可以找到目標。 

通俗易懂的例子

這個就像是有一百把鑰匙,你突然覺得,我從頭找是不是太慢了,我從中間找,比如我要找到23號的房間鑰匙,我從中間切開,找到50編號的位置,然後23在1~50裡面,我再把從中間切開變成25,然後23在1~25之間,我再切開變成12.5,然後23在12.5~25之間,依次找下去,直到找到鑰匙。這種查詢鑰匙的方法的複雜度就是o(log^n)

o(n log n)解析

o(n log n)同理,就是n乘以log n,當資料增大256倍時,耗時增大256*8=2048倍。這個複雜度高於線性低於平方。歸併排序就是o(n log n)的時間複雜度。

時間複雜度 空間複雜度

時間複雜度 在電腦科學中,演算法的時間複雜度是乙個函式,它定性描述了該演算法的執行時間。這是乙個關於代表演算法輸入值的字串 的長度的函式。時間複雜度常用大o符號 表述,不包括這個函式的低階項和首項係數。計算時間複雜度的方法 1 只保留高階項,低階項直接丟棄 2 係數不要 3 執行次數是常數是為o 1...

時間複雜度 空間複雜度

演算法複雜度分為時間複雜度和空間複雜度。其作用 時間複雜度是指執行演算法所需要的計算工作量 而空間複雜度是指執行這個演算法所需要的記憶體空間。一 時間複雜度 時間頻度 乙個演算法執行所耗費的時間,從理論上是不能算出來的,必須上機執行測試才能知道。但我們不可能也沒有必要對每個演算法都上機測試,只需知道...

時間複雜度 空間複雜度

一 時間複雜度 實際是指程式執行次數,而不是程式執行時間 1.我們一般討論的是最壞時間複雜度,這樣做的原因是 最壞情況下的時間複雜度是演算法在任何輸入例項上執行時間的上限,以最壞代表最全。2.時間複雜度的書寫規則 忽略常數項,用o 1 表示 選取最壞時間複雜度即選取增長最快的項 遞迴的時間複雜度 遞...