日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

【转】算法中时间复杂度概括——o(1)、o(n)、o(logn)、o(nlogn)

發布時間:2025/7/14 编程问答 32 豆豆
生活随笔 收集整理的這篇文章主要介紹了 【转】算法中时间复杂度概括——o(1)、o(n)、o(logn)、o(nlogn) 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

2019獨角獸企業重金招聘Python工程師標準>>>

? ? ? ?在描述算法復雜度時,經常用到o(1), o(n), o(logn), o(nlogn)來表示對應算法的時間復雜度。這里進行歸納一下它們代表的含義:這是算法的時空復雜度的表示。不僅僅用于表示時間復雜度,也用于表示空間復雜度。
?
? ? ? O后面的括號中有一個函數,指明某個算法的耗時/耗空間與數據增長量之間的關系。其中的n代表輸入數據的量。

  • 比如時間復雜度為O(n),就代表數據量增大幾倍,耗時也增大幾倍。比如常見的遍歷算法。
  • 再比如時間復雜度O(n^2),就代表數據量增大n倍時,耗時增大n的平方倍,這是比線性更高的時間復雜度。比如冒泡排序,就是典型的O(n^2)的算法,對n個數排序,需要掃描n×n次。
  • 再比如O(logn),當數據增大n倍時,耗時增大logn倍(這里的log是以2為底的,比如,當數據增大256倍時,耗時只增大8倍,是比線性還要低的時間復雜度)。二分查找就是O(logn)的算法,每找一次排除一半的可能,256個數據中查找只要找8次就可以找到目標。
  • O(nlogn)同理,就是n乘以logn,當數據增大256倍時,耗時增大256*8=2048倍。這個復雜度高于線性低于平方。歸并排序就是O(nlogn)的時間復雜度。
  • O(1)就是最低的時空復雜度了,也就是耗時/耗空間與輸入數據大小無關,無論輸入數據增大多少倍,耗時/耗空間都不變。 哈希算法就是典型的O(1)時間復雜度,無論數據規模多大,都可以在一次計算后找到目標(不考慮沖突的話)
  • 轉載于:https://my.oschina.net/maojindaoGG/blog/3054352

    總結

    以上是生活随笔為你收集整理的【转】算法中时间复杂度概括——o(1)、o(n)、o(logn)、o(nlogn)的全部內容,希望文章能夠幫你解決所遇到的問題。

    如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。