快速理解算法時(shí)間復(fù)雜度

算法在移動(dòng)端開發(fā)中用到的并不多但是在面試時(shí)面試官為了試探你的水平經(jīng)常會問到。這塊在大學(xué)的時(shí)候數(shù)據(jù)結(jié)構(gòu)那門課中講的挺多的妙黍,各種排序悴侵,查找算法的時(shí)間復(fù)雜度,當(dāng)時(shí)理解的不夠好所以再來學(xué)習(xí)下拭嫁。

一個(gè)程序執(zhí)行的的時(shí)間是需要通過上機(jī)來確定的而且你取決于你的CPU的運(yùn)算能力可免,時(shí)間復(fù)雜度只是在算法中進(jìn)行的橫向?qū)Ρ?/code>不代表具體的時(shí)間。

1噩凹、時(shí)間頻度:一個(gè)算法中的語句執(zhí)行次數(shù)稱為語句頻度或時(shí)間頻度記作:T(N)

int test(void) {
    printf("Hello, World!\n");      //  需要執(zhí)行 1 次
    return 0;       // 需要執(zhí)行 1 次
}

這個(gè)test類的時(shí)間頻度為T(2)

int aFunc(int n) {
    for(int i = 0; i<n; i++) {         // 需要執(zhí)行 (n + 1) 次
        printf("Hello, World!\n");      // 需要執(zhí)行 n 次
    }
    return 0;       // 需要執(zhí)行 1 次
}

這個(gè)時(shí)間頻度為n+1+n+1也就是T(2n+2)
時(shí)間頻度這個(gè)概念還是比較好理解的就是數(shù)一下當(dāng)前程序所有的語句每一句語句加起來一共執(zhí)行了多少次巴元。

開始引入時(shí)間復(fù)雜度的概念

存在常數(shù) c 和函數(shù) f(N),使得當(dāng) N >= c 時(shí) T(N) <= f(N)驮宴,表示為 T(n) = O(f(n)) 逮刨。
如圖:

時(shí)間復(fù)雜度示意圖

直線為T(n)=2n+2,曲線為f(n)=n^2
對圖中的兩條線進(jìn)行解釋:當(dāng)n=2是T(n)=f(n)則稱這個(gè)使f(n)=T(n)的這個(gè)n值2為C,當(dāng)n>C時(shí)f(n)的增長速度永遠(yuǎn)大于T(n)也就是f(n)是T(n)的上界堵泽。則可以表示為 T(n) = O(f(n))修己。

時(shí)間復(fù)雜度怎么計(jì)算:

本文開始的兩個(gè)例子:
1、T(n)=2則f(n)=2所以可以推算出O(f(n))=O(2)(這樣表示并不正確下面會解釋)
2迎罗、T(n)=2n+2所以可以推算出O(f(n))=O(2n+2)(這樣表示并不正確下面會解釋)

上面的這兩個(gè)例子的表示方法為什么不不正確的呢睬愤?從時(shí)間復(fù)雜度的定義可以看出來大O的表示法是一個(gè)極值或者說是一個(gè)不準(zhǔn)確的值它只是表示了T(n)的變化速率所以說大O推導(dǎo)出來大O還需要一些方法,一共三種:

1.用常數(shù)1來取代運(yùn)行時(shí)間中所有加法常數(shù)纹安。
2.修改后的運(yùn)行次數(shù)函數(shù)中尤辱,只保留最高階項(xiàng)
3.如果最高階項(xiàng)存在且不是1,則去除與這個(gè)項(xiàng)相乘的常數(shù)厢岂。

從這三條規(guī)律可以得出第一個(gè)應(yīng)該是O(1)光督,第二個(gè)應(yīng)該是O(2n),當(dāng)然還有l(wèi)ogn,n^2等算法塔粒,可以參考皇叔的博客

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末结借,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子卒茬,更是在濱河造成了極大的恐慌船老,老刑警劉巖,帶你破解...
    沈念sama閱讀 211,290評論 6 491
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件圃酵,死亡現(xiàn)場離奇詭異柳畔,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)辜昵,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,107評論 2 385
  • 文/潘曉璐 我一進(jìn)店門荸镊,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人堪置,你說我怎么就攤上這事躬存。” “怎么了舀锨?”我有些...
    開封第一講書人閱讀 156,872評論 0 347
  • 文/不壞的土叔 我叫張陵岭洲,是天一觀的道長。 經(jīng)常有香客問我坎匿,道長盾剩,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 56,415評論 1 283
  • 正文 為了忘掉前任替蔬,我火速辦了婚禮告私,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘承桥。我一直安慰自己驻粟,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,453評論 6 385
  • 文/花漫 我一把揭開白布凶异。 她就那樣靜靜地躺著蜀撑,像睡著了一般。 火紅的嫁衣襯著肌膚如雪剩彬。 梳的紋絲不亂的頭發(fā)上酷麦,一...
    開封第一講書人閱讀 49,784評論 1 290
  • 那天,我揣著相機(jī)與錄音喉恋,去河邊找鬼沃饶。 笑死,一個(gè)胖子當(dāng)著我的面吹牛轻黑,可吹牛的內(nèi)容都是我干的糊肤。 我是一名探鬼主播,決...
    沈念sama閱讀 38,927評論 3 406
  • 文/蒼蘭香墨 我猛地睜開眼苔悦,長吁一口氣:“原來是場噩夢啊……” “哼轩褐!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起玖详,我...
    開封第一講書人閱讀 37,691評論 0 266
  • 序言:老撾萬榮一對情侶失蹤把介,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后蟋座,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體拗踢,經(jīng)...
    沈念sama閱讀 44,137評論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,472評論 2 326
  • 正文 我和宋清朗相戀三年向臀,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了巢墅。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 38,622評論 1 340
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖君纫,靈堂內(nèi)的尸體忽然破棺而出驯遇,到底是詐尸還是另有隱情,我是刑警寧澤蓄髓,帶...
    沈念sama閱讀 34,289評論 4 329
  • 正文 年R本政府宣布叉庐,位于F島的核電站,受9級特大地震影響会喝,放射性物質(zhì)發(fā)生泄漏陡叠。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,887評論 3 312
  • 文/蒙蒙 一肢执、第九天 我趴在偏房一處隱蔽的房頂上張望枉阵。 院中可真熱鬧,春花似錦预茄、人聲如沸兴溜。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,741評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽昵慌。三九已至,卻和暖如春淮蜈,著一層夾襖步出監(jiān)牢的瞬間斋攀,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,977評論 1 265
  • 我被黑心中介騙來泰國打工梧田, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留淳蔼,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 46,316評論 2 360
  • 正文 我出身青樓裁眯,卻偏偏與公主長得像鹉梨,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個(gè)殘疾皇子穿稳,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,490評論 2 348