javascript - 计算一个数字的数列它为什么能瞬间出结果?
PHP中文网
PHP中文网 2017-04-11 12:16:46
[JavaScript讨论组]

请教个问题,计算一个数字的数列是要很长时间的,如下函数:

function res(n){
    return n < 2 ? n : res(n - 1) + res(n - 2);
}
var start = new Date();
console.log(res(43));
console.log(new Date()-start+'ms');

Chrome执行结果如下:
433494437
8358ms
但是下面的函数res_1在没有经过缓存计算结果的前提下也能瞬间出结果,这是什么原理?

function res_1(n){
    if(!res_1.cache[n]){
        return res_1.cache[n] = n < 2 ? n : res_1(n - 1) + res_1(n - 2);
    }
    return res_1.cache[n];
}
res_1.cache = {};
var start = new Date();
console.log(res_1(43));
console.log(new Date()-start+'ms');

Chrome执行结果如下:
433494437
0ms

计算45的数列:

start = new Date();
console.log(res_1(45));
console.log(new Date()-start+'ms');

结果如下,未经过缓存
1134903170
0ms
而用res函数计算45的数列,要25468ms

PHP中文网
PHP中文网

认证0级讲师

全部回复(1)
怪我咯

可是res_1的计算过程中在一直做缓存啊,你为什么说没做缓存。

热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号