今天的风儿有点喧嚣 2016-08-28 02:38 采纳率: 71.4%
浏览 1230

js测试带记忆功能的递归函数和不带记忆功能的递归函数的执行时间具体哪个更快?

#js
代码如下:

 <!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Document</title>
    <script type="text/javascript">
    //"use strict"
    /*生成带记忆功能的函数*/
        function memorize(f){
            var cache={};
            return function(){
                var key=arguments.length+Array.prototype.join.call(arguments,",");
                if(key in cache){
                    return cache[key];
                }else{
                    return cache[key]=f.apply(this,arguments);
                }
            }
        }
    /*递归计算n的阶乘*/
        function nj(n){
            if(isFinite(n)&&n>0&&n==Math.round(n)){
                if(!(n in nj))
                    nj[n]=n*nj(n-1);
                return nj[n];
            }
            else return NaN;
        }
        nj[1]=1;

        var menj=memorize(nj);
        menj[1]=1;
        menj(80);//记录结果


        var ms=(new Date).getTime();
        console.log(ms);
        console.log(menj(80));
        console.log((new Date).getTime()-ms);
        console.log("-----------------------------------------")
        var s=(new Date).getTime();
        console.log(s);
        console.log(nj(80));
        console.log((new Date).getTime()-s);


    </script>
</head>
<body>

</body>
</html>

为什么不带记忆功能的递归函数的执行时间比带记忆功能的递归函数的执行时间短?

  • 写回答

1条回答 默认 最新

  • threenewbee 2016-08-28 08:53
    关注

    如果都是第一次运行,那么记忆的更慢是正常的,因为在没有运行以前,记忆是没有的。

    评论

报告相同问题?

悬赏问题

  • ¥500 把面具戴到人脸上,请大家贡献智慧
  • ¥15 任意一个散点图自己下载其js脚本文件并做成独立的案例页面,不要作在线的,要离线状态。
  • ¥15 各位 帮我看看如何写代码,打出来的图形要和如下图呈现的一样,急
  • ¥30 c#打开word开启修订并实时显示批注
  • ¥15 如何解决ldsc的这条报错/index error
  • ¥15 VS2022+WDK驱动开发环境
  • ¥30 关于#java#的问题,请各位专家解答!
  • ¥30 vue+element根据数据循环生成多个table,如何实现最后一列 平均分合并
  • ¥20 pcf8563时钟芯片不启振
  • ¥20 pip2.40更新pip2.43时报错