js緩存加快運(yùn)行速度

今天在做一個(gè)樹(shù)形結(jié)構(gòu)計(jì)算時(shí)使用了遞歸废菱,使用js計(jì)算抖誉,樹(shù)一旦比較大了衰倦,頁(yè)面經(jīng)程宦卡頓樊零,后來(lái)調(diào)試發(fā)現(xiàn)問(wèn)題出在遞歸函數(shù)上,后來(lái)給每個(gè)葉節(jié)點(diǎn)加了計(jì)算緩存才算解決了問(wèn)題驻襟。
為了弄明白究竟慢在哪里,自己做了個(gè)實(shí)驗(yàn)塑悼,以簡(jiǎn)單的斐波那契數(shù)列為例,先定義一個(gè)簡(jiǎn)單函數(shù)

f=function(n){
    return n<2?n:f(n-1)+f(n-2);
}

再定義一個(gè)時(shí)間計(jì)算函數(shù)

time=function(func){
    function dofunc(n){
        var t1=new Date();
        var r=func(n);
        var t2=new Date();
        console.log((t2-t1)+'ms');
        return r;
    }
    return dofunc
}

好了現(xiàn)在看看運(yùn)行時(shí)間

命令 ftime=time(f) 結(jié)果 時(shí)間
ftime(30) 832040 1369ms
ftime(31) 1346269 2199ms
ftime(32) 2178309 3533ms
ftime(33) 3524578 5884ms

再往上去厢蒜,我這電腦已經(jīng)扛不住了,居然只能算到30左右斑鸦。。巷屿。
如果加個(gè)緩存試試呢

重新定義一個(gè)帶緩存的ff函數(shù)

ff=function(){
    mem=[0,1];
    function f(n){
        var r=mem[n];
        if(typeof(r)!='undefined'){
            return r;
        }else{
            mem[n]=f(n-2)+f(n-1)
            return mem[n];
        }
    }
    return f
}()

再來(lái)看看運(yùn)行時(shí)間

命令 ftime=time(ff) 結(jié)果 時(shí)間
fftime(30) 832040 0ms
fftime(300) 2.2223224462942035e+62 1ms
fftime(1000) 4.346655768693743e+208 1ms
fftime(3000) Infinity 2ms

太出乎我的意料了墩虹,也難怪那些大公司都對(duì)算法是有要求的...

PS:后來(lái)想用快一點(diǎn)的語(yǔ)言會(huì)不會(huì)好些嘱巾,于是用python測(cè)試了一下性能诫钓,發(fā)現(xiàn)也就是比js快個(gè)3、4倍的樣子菌湃,不過(guò)遇到這樣指數(shù)級(jí)的問(wèn)題,光靠語(yǔ)言間的快慢是無(wú)法解決的惧所,C/C++大拿不要嘲笑,我確實(shí)不會(huì)下愈。。势似。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市辖佣,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌卷谈,老刑警劉巖,帶你破解...
    沈念sama閱讀 218,941評(píng)論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件世蔗,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡污淋,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,397評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門(mén)寸爆,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)礁鲁,“玉大人,你說(shuō)我怎么就攤上這事赁豆〗龃迹” “怎么了?”我有些...
    開(kāi)封第一講書(shū)人閱讀 165,345評(píng)論 0 356
  • 文/不壞的土叔 我叫張陵魔种,是天一觀的道長(zhǎng)析二。 經(jīng)常有香客問(wèn)我,道長(zhǎng)节预,這世上最難降的妖魔是什么叶摄? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,851評(píng)論 1 295
  • 正文 為了忘掉前任,我火速辦了婚禮安拟,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘去扣。我一直安慰自己柱衔,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,868評(píng)論 6 392
  • 文/花漫 我一把揭開(kāi)白布愉棱。 她就那樣靜靜地躺著唆铐,像睡著了一般。 火紅的嫁衣襯著肌膚如雪奔滑。 梳的紋絲不亂的頭發(fā)上艾岂,一...
    開(kāi)封第一講書(shū)人閱讀 51,688評(píng)論 1 305
  • 那天,我揣著相機(jī)與錄音朋其,去河邊找鬼王浴。 笑死脆炎,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的氓辣。 我是一名探鬼主播秒裕,決...
    沈念sama閱讀 40,414評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼钞啸!你這毒婦竟也來(lái)了几蜻?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書(shū)人閱讀 39,319評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤体斩,失蹤者是張志新(化名)和其女友劉穎梭稚,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體絮吵,經(jīng)...
    沈念sama閱讀 45,775評(píng)論 1 315
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡弧烤,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,945評(píng)論 3 336
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了蹬敲。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片暇昂。...
    茶點(diǎn)故事閱讀 40,096評(píng)論 1 350
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖粱栖,靈堂內(nèi)的尸體忽然破棺而出话浇,到底是詐尸還是另有隱情脏毯,我是刑警寧澤闹究,帶...
    沈念sama閱讀 35,789評(píng)論 5 346
  • 正文 年R本政府宣布,位于F島的核電站食店,受9級(jí)特大地震影響渣淤,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜吉嫩,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,437評(píng)論 3 331
  • 文/蒙蒙 一价认、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧自娩,春花似錦用踩、人聲如沸。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 31,993評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至姊扔,卻和暖如春惠奸,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背恰梢。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 33,107評(píng)論 1 271
  • 我被黑心中介騙來(lái)泰國(guó)打工佛南, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留梗掰,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 48,308評(píng)論 3 372
  • 正文 我出身青樓嗅回,卻偏偏與公主長(zhǎng)得像及穗,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子绵载,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,037評(píng)論 2 355

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