Swift算法-Big O notation

聲明:算法和數(shù)據(jù)結(jié)構(gòu)的文章均是作者從github上翻譯過(guò)來(lái)光绕,為方便大家閱讀茄靠。如果英語(yǔ)閱讀能力強(qiáng)的朋友秕岛,可以直接到swift算法俱樂(lè)部查看所有原文寿弱,以便快速學(xué)習(xí)。作者同時(shí)也在學(xué)習(xí)中才睹,歡迎交流。

在編程過(guò)程中,了解一個(gè)算法的速度和消耗內(nèi)存是非常有用的揪阿,它可以讓你在不同的情況選擇合適的算法。

通過(guò)大O符號(hào)可以讓你對(duì)算法的運(yùn)行速度和內(nèi)存消耗有粗略的判斷咆畏。當(dāng)有人說(shuō):“這個(gè)算法比O(n^2)跑得慢南捂,占用了O(n)的空間【烧遥”他們的意思是溺健,這個(gè)算法有點(diǎn)慢,但是不需要太多額外的內(nèi)存钮蛛。

理解算法的大O符號(hào)通常是經(jīng)過(guò)數(shù)學(xué)分析鞭缭。這里我們不討論數(shù)學(xué)剖膳,但是了解不同的值所代表的意思還是有必要的,如下圖岭辣。N代表你在處理的數(shù)據(jù)總量吱晒。比如,排序一個(gè)含有100個(gè)元素的數(shù)組沦童,n=100仑濒。

大0符號(hào)描述

通常情況下你不需要用數(shù)學(xué)推理去知道一個(gè)算法的大O,只需要簡(jiǎn)單的憑自覺(jué)搞动。如果你的代碼使用的是單一循環(huán)來(lái)查看所有的輸入數(shù)據(jù)躏精,那這個(gè)算法就是O(n)。如果你的代碼使用的是兩層嵌套循環(huán)鹦肿,那這個(gè)算法就是O(n^2)矗烛。三次嵌套循環(huán)就是O(n^3),以此類(lèi)推箩溃。

必須注意大O符號(hào)只是一個(gè)大致判斷瞭吃,同時(shí)它只適合數(shù)據(jù)總量大的情況。比如涣旨,對(duì)于插入排序算法O(n^2)是屬于運(yùn)行時(shí)間較長(zhǎng)的歪架,理論上會(huì)比歸類(lèi)排序算法O(nlogn)來(lái)的更久。但是在小數(shù)據(jù)總量的時(shí)候霹陡,插入排序算法卻比歸類(lèi)排序算法更快和蚪,特別是當(dāng)數(shù)組已經(jīng)是部分排序好的情況下!

如果你感覺(jué)很迷惑烹棉,請(qǐng)不要讓大o符號(hào)困擾你太多攒霹。在對(duì)比兩個(gè)算法的優(yōu)劣時(shí)候它是非常有用的!重點(diǎn)是要不斷的去嘗試浆洗。當(dāng)然催束,在數(shù)據(jù)總量很小的時(shí)候,即使是實(shí)際應(yīng)用伏社,一個(gè)糟糕的算法也可以取得不錯(cuò)的效果抠刺。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市摘昌,隨后出現(xiàn)的幾起案子速妖,更是在濱河造成了極大的恐慌,老刑警劉巖聪黎,帶你破解...
    沈念sama閱讀 206,482評(píng)論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件罕容,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)杀赢,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,377評(píng)論 2 382
  • 文/潘曉璐 我一進(jìn)店門(mén),熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)湘纵,“玉大人脂崔,你說(shuō)我怎么就攤上這事∥嗯纾” “怎么了砌左?”我有些...
    開(kāi)封第一講書(shū)人閱讀 152,762評(píng)論 0 342
  • 文/不壞的土叔 我叫張陵,是天一觀(guān)的道長(zhǎng)铺敌。 經(jīng)常有香客問(wèn)我汇歹,道長(zhǎng),這世上最難降的妖魔是什么偿凭? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 55,273評(píng)論 1 279
  • 正文 為了忘掉前任产弹,我火速辦了婚禮,結(jié)果婚禮上弯囊,老公的妹妹穿的比我還像新娘痰哨。我一直安慰自己,他們只是感情好匾嘱,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,289評(píng)論 5 373
  • 文/花漫 我一把揭開(kāi)白布斤斧。 她就那樣靜靜地躺著,像睡著了一般霎烙。 火紅的嫁衣襯著肌膚如雪撬讽。 梳的紋絲不亂的頭發(fā)上,一...
    開(kāi)封第一講書(shū)人閱讀 49,046評(píng)論 1 285
  • 那天悬垃,我揣著相機(jī)與錄音游昼,去河邊找鬼。 笑死盗忱,一個(gè)胖子當(dāng)著我的面吹牛酱床,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播趟佃,決...
    沈念sama閱讀 38,351評(píng)論 3 400
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼扇谣,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了闲昭?” 一聲冷哼從身側(cè)響起罐寨,我...
    開(kāi)封第一講書(shū)人閱讀 36,988評(píng)論 0 259
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎序矩,沒(méi)想到半個(gè)月后鸯绿,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 43,476評(píng)論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 35,948評(píng)論 2 324
  • 正文 我和宋清朗相戀三年瓶蝴,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了毒返。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 38,064評(píng)論 1 333
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡舷手,死狀恐怖拧簸,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情男窟,我是刑警寧澤盆赤,帶...
    沈念sama閱讀 33,712評(píng)論 4 323
  • 正文 年R本政府宣布,位于F島的核電站歉眷,受9級(jí)特大地震影響牺六,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜汗捡,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,261評(píng)論 3 307
  • 文/蒙蒙 一淑际、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧凉唐,春花似錦庸追、人聲如沸。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 30,264評(píng)論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至簿训,卻和暖如春咱娶,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背强品。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 31,486評(píng)論 1 262
  • 我被黑心中介騙來(lái)泰國(guó)打工膘侮, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人的榛。 一個(gè)月前我還...
    沈念sama閱讀 45,511評(píng)論 2 354
  • 正文 我出身青樓琼了,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親夫晌。 傳聞我的和親對(duì)象是個(gè)殘疾皇子雕薪,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,802評(píng)論 2 345

推薦閱讀更多精彩內(nèi)容

  • 概述:排序有內(nèi)部排序和外部排序,內(nèi)部排序是數(shù)據(jù)記錄在內(nèi)存中進(jìn)行排序晓淀,而外部排序是因排序的數(shù)據(jù)很大所袁,一次不能容納全部...
    每天刷兩次牙閱讀 3,727評(píng)論 0 15
  • 概述 排序有內(nèi)部排序和外部排序,內(nèi)部排序是數(shù)據(jù)記錄在內(nèi)存中進(jìn)行排序凶掰,而外部排序是因排序的數(shù)據(jù)很大燥爷,一次不能容納全部...
    蟻前閱讀 5,164評(píng)論 0 52
  • 小兵喜歡的女孩子跟他說(shuō)她希望有一天她的婚禮能在法國(guó)最大的教堂舉行蜈亩,穿上高級(jí)定制的婚紗,捧著來(lái)自荷蘭的藍(lán)玫瑰前翎。自那天...
    cmn_f838閱讀 272評(píng)論 0 0