玩轉(zhuǎn)數(shù)據(jù)結(jié)構(gòu)之均攤時(shí)間復(fù)雜度

0. 序言

如果你對(duì)簡(jiǎn)單的復(fù)雜度分析不了解鲜锚,請(qǐng)?zhí)D(zhuǎn)閱讀:http://www.reibang.com/p/2d5e5f1bc77e
如果你想看常見的時(shí)間復(fù)雜度實(shí)例分析狈定,請(qǐng)?zhí)D(zhuǎn)閱讀:http://www.reibang.com/p/4c8fa84a9393
閱讀本篇文章,建議先跳轉(zhuǎn)閱讀:http://www.reibang.com/p/08d1d509c5db
如果你對(duì)簡(jiǎn)單的復(fù)雜度分析以及常見的時(shí)間復(fù)雜度以及最好瓜富、最壞鳍咱、平均時(shí)間復(fù)雜度已經(jīng)了解,想對(duì)均攤時(shí)間復(fù)雜度有更多的了解食呻,那么你可以閱讀本篇文章流炕,一定會(huì)讓你有所收獲澎现。

1. 簡(jiǎn)介

均攤時(shí)間復(fù)雜度仅胞,在我看來(lái),是平均時(shí)間復(fù)雜度的補(bǔ)充剑辫。平均時(shí)間復(fù)雜度只在某些特殊情況下才會(huì)用到干旧,而均攤時(shí)間復(fù)雜度應(yīng)用的場(chǎng)景比它更加特殊、更加有限妹蔽。

2. 應(yīng)用場(chǎng)景

 // array 表示一個(gè)長(zhǎng)度為 n 的數(shù)組
 // 代碼中的 array.length 就等于 n
 int[] array = new int[n];
 int count = 0;
 
 void insert(int val) {
    if (count == array.length) {
       int sum = 0;
       for (int i = 0; i < array.length; ++i) {
          sum = sum + array[i];
       }
       array[0] = sum;
       count = 1;
    }

    array[count] = val;
    ++count;
 }

這段代碼實(shí)現(xiàn)了往數(shù)據(jù)中插入數(shù)據(jù)的功能椎眯。當(dāng)數(shù)組沒(méi)有滿的時(shí)候挠将,直接插入數(shù)據(jù)到數(shù)組中。當(dāng)數(shù)組滿了以后编整,遍歷數(shù)組求和舔稀,將求和之后的sum值放在數(shù)組中的第一位置,然后把count指針指向索引為1的位置掌测,再將新的數(shù)據(jù)插入内贮。

我們看下這段代碼的最好、最壞汞斧、平均時(shí)間復(fù)雜度夜郁。當(dāng)數(shù)組沒(méi)有滿的時(shí)候,直接將數(shù)據(jù)插入數(shù)組中即可粘勒,這是最理想的情況竞端,所以最好時(shí)間復(fù)雜度為O(1)。當(dāng)數(shù)組滿的時(shí)候庙睡,需要遍歷數(shù)組求和事富,把求和后的數(shù)據(jù)插入,這是最壞的情況乘陪,所以最壞情況的時(shí)間復(fù)雜度為O(n)赵颅。

平均時(shí)間復(fù)雜度是多少呢?我們分析下:假設(shè)數(shù)組的長(zhǎng)度是n暂刘,根據(jù)數(shù)據(jù)插入的位置的不同饺谬,我們可以分為n種情況,每種情況的時(shí)間復(fù)雜度是O(1).當(dāng)數(shù)組滿了的時(shí)候插入一個(gè)數(shù)據(jù)谣拣,這個(gè)時(shí)候需要遍歷求和募寨,這個(gè)時(shí)候的時(shí)間復(fù)雜度是O(n),而n+1種情況發(fā)生的概率一樣森缠,都是1/n+1拔鹰。所以根據(jù)加權(quán)平均計(jì)算法,求得的平均時(shí)間復(fù)雜度是:


平均時(shí)間復(fù)雜度

以上的O(1)是去掉系數(shù)和常數(shù)得出來(lái)的結(jié)果贵涵。

但是你會(huì)發(fā)現(xiàn)這段代碼平均時(shí)間復(fù)雜度的分析并不需要引入概率列肢。我們對(duì)比下find示例(http://www.reibang.com/p/08d1d509c5db)和以上insert示例,發(fā)現(xiàn)兩者有很大區(qū)別:
① find函數(shù)在極端情況下宾茂,復(fù)雜度才為O(1),但insert在大部分情況下瓷马,時(shí)間復(fù)雜度都為O(1),只有個(gè)別情況下,時(shí)間復(fù)雜度才是O(n).
② insert函數(shù)跨晴,O(1)時(shí)間復(fù)雜度的插入和O(n)時(shí)間復(fù)雜度的插入欧聘,出現(xiàn)的頻率都是有規(guī)律可循的,先是n個(gè)O(1)的插入端盆,然后是O(n)的遍歷求和插入怀骤,接著是1個(gè)O(1)的操作费封,緊跟著是n-1個(gè)O(1)的操作,然后循環(huán)往復(fù)后面三種操作蒋伦。
綜上你會(huì)發(fā)現(xiàn)弓摘,find操作在執(zhí)行的時(shí)候,你并不知道find操作會(huì)執(zhí)行多少次痕届,因?yàn)閿?shù)據(jù)不同衣盾,發(fā)生的find的概率不同,所以用加權(quán)平均時(shí)間復(fù)雜度分析比較合理爷抓,而insert操作在執(zhí)行的時(shí)候势决,因?yàn)橛幸?guī)律可循,所以很多情況下蓝撇,insert執(zhí)行插入的位置的概率是100%的O(1)果复,而只有很少情況是O(n)——針對(duì)大部分執(zhí)行100%概率是低階,很少概率是高階時(shí)間復(fù)雜度的情況渤昌,我們不適合用平均時(shí)間復(fù)雜度去分析虽抄,這個(gè)時(shí)候用均攤時(shí)間復(fù)雜度分析較為合理。

顧名思義:均攤復(fù)雜度独柑,就是把量級(jí)高的操作所耗費(fèi)的時(shí)間分擔(dān)到量級(jí)低的操作上迈窟,看平攤后的量級(jí)是多少。拿上面的例子來(lái)說(shuō):每次O(n)的遍歷求和操作后面忌栅,會(huì)跟著1次O(1)的插入操作车酣,然后跟著n-1次O(1)的插入操作,所以把耗時(shí)多的遍歷求和操作的時(shí)間均攤到接下來(lái)的n次耗時(shí)少的操作上索绪,也就是平均執(zhí)行2次操作湖员,所以這一組連續(xù)的操作的均攤復(fù)雜度就是O(1)。

綜上:對(duì)一個(gè)數(shù)據(jù)結(jié)構(gòu)進(jìn)行一組連續(xù)操作瑞驱,大部分情況下時(shí)間復(fù)雜度都很低娘摔,只有個(gè)別情況下時(shí)間復(fù)雜度比較高,而且這些操作之間存在前后連貫的時(shí)序關(guān)系唤反,這個(gè)時(shí)候凳寺,適合運(yùn)用均攤復(fù)雜度分析代碼,而此時(shí)均攤時(shí)間復(fù)雜度就等于最好情況時(shí)間復(fù)雜度彤侍。

3. 后續(xù)

如果大家喜歡這篇文章肠缨,歡迎點(diǎn)贊!
如果想看更多 數(shù)據(jù)結(jié)構(gòu) 方面的文章拥刻,歡迎關(guān)注!

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末怜瞒,一起剝皮案震驚了整個(gè)濱河市父泳,隨后出現(xiàn)的幾起案子般哼,更是在濱河造成了極大的恐慌吴汪,老刑警劉巖,帶你破解...
    沈念sama閱讀 221,273評(píng)論 6 515
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件蒸眠,死亡現(xiàn)場(chǎng)離奇詭異漾橙,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)楞卡,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,349評(píng)論 3 398
  • 文/潘曉璐 我一進(jìn)店門霜运,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人蒋腮,你說(shuō)我怎么就攤上這事淘捡。” “怎么了池摧?”我有些...
    開封第一講書人閱讀 167,709評(píng)論 0 360
  • 文/不壞的土叔 我叫張陵焦除,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我作彤,道長(zhǎng)膘魄,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 59,520評(píng)論 1 296
  • 正文 為了忘掉前任竭讳,我火速辦了婚禮创葡,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘绢慢。我一直安慰自己灿渴,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 68,515評(píng)論 6 397
  • 文/花漫 我一把揭開白布胰舆。 她就那樣靜靜地躺著逻杖,像睡著了一般。 火紅的嫁衣襯著肌膚如雪思瘟。 梳的紋絲不亂的頭發(fā)上荸百,一...
    開封第一講書人閱讀 52,158評(píng)論 1 308
  • 那天,我揣著相機(jī)與錄音滨攻,去河邊找鬼够话。 笑死,一個(gè)胖子當(dāng)著我的面吹牛光绕,可吹牛的內(nèi)容都是我干的女嘲。 我是一名探鬼主播,決...
    沈念sama閱讀 40,755評(píng)論 3 421
  • 文/蒼蘭香墨 我猛地睜開眼诞帐,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼欣尼!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,660評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤愕鼓,失蹤者是張志新(化名)和其女友劉穎钙态,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體菇晃,經(jīng)...
    沈念sama閱讀 46,203評(píng)論 1 319
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡册倒,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,287評(píng)論 3 340
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了磺送。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片驻子。...
    茶點(diǎn)故事閱讀 40,427評(píng)論 1 352
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖估灿,靈堂內(nèi)的尸體忽然破棺而出崇呵,到底是詐尸還是另有隱情,我是刑警寧澤馅袁,帶...
    沈念sama閱讀 36,122評(píng)論 5 349
  • 正文 年R本政府宣布演熟,位于F島的核電站,受9級(jí)特大地震影響司顿,放射性物質(zhì)發(fā)生泄漏芒粹。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,801評(píng)論 3 333
  • 文/蒙蒙 一大溜、第九天 我趴在偏房一處隱蔽的房頂上張望化漆。 院中可真熱鬧,春花似錦钦奋、人聲如沸座云。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,272評(píng)論 0 23
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)朦拖。三九已至,卻和暖如春厌衔,著一層夾襖步出監(jiān)牢的瞬間璧帝,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,393評(píng)論 1 272
  • 我被黑心中介騙來(lái)泰國(guó)打工富寿, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留睬隶,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 48,808評(píng)論 3 376
  • 正文 我出身青樓页徐,卻偏偏與公主長(zhǎng)得像苏潜,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子变勇,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,440評(píng)論 2 359

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