养兔子Fibo函数优化

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<body>
<script>
    /* var cache = (function createCache() {
     var data = [];

     return function cache(key, value) {
     if (data.length > 3){
     var temp = data.shift();
     delete cache[temp];
     }
     data.push(key);
     cache[key] = value;
     }
     })();

     cache("_name","zs");*/

    /* function createCache() {
     var arr = [];
     return function cache(key, value) {
     if (arr.length >= 3) {
     var temp = arr.shift();
     delete cache[temp];
     }
     arr.push(key);
     cache[key] = value;
     }
     }
     var cache = createCache();
     cache(‘_name1‘, ‘z‘);
     cache(‘_name2‘, ‘zs‘);
     cache(‘_name3‘, ‘zds‘);
     cache(‘_name4‘, ‘zadf‘);*/
    var month =  prompt("请输入月数:")
    function fibobo(x) {
        var arr = [1, 1];
        // var arr = [];
        (function fib(n) {
            if (n === 0 || n === 1) {
                return 1;
            }
            if (!arr[n]) {
                arr.push(fib(n - 1) + fib(n - 2));
                return arr[n];
            } else {
                return arr[n];
            }
        })(x);

        // console.log(arr)

        return arr[x - 1];
    }
    // var begin1 = +new Date();
    console.time(‘优化后方案‘)
    console.log(month+"个月后有"+fibobo(month)+"只兔子");
    // var end1  = +new Date();
    // console.log (end1-begin1);
    console.timeEnd(‘优化后方案‘)
    function fib(n) {
        if (n<=2){
           return 1 ;
        }
        return fib(n -1 ) + fib(n - 2);
    }
    console.time(‘优化前方案‘)
    console.log(month+"个月后有"+fib(month)+"只兔子");
    console.timeEnd(‘优化前方案‘);
   /* function Fib ( n ) {
        if ( n === 1 || n === 2 ) return 1;
        return Fib ( n - 1 ) + Fib ( n - 2 );
    }
    console.time(‘c‘)
    console.log(month+"个月后有"+Fib(month)+"只兔子");
    console.timeEnd(‘c‘);
    */
    /*
     var o = {
     a: 1,
     b: 2
     }
     var o1 = {};
     for (var key in o) {
     o1[key] = o [key]
     }
     console.log(o1)
     console.log(o.length)*/

</script>
</body>
</html>
时间: 2024-08-08 13:55:59

养兔子Fibo函数优化的相关文章

poj 2154 Color(polya计数 + 欧拉函数优化)

http://poj.org/problem?id=2154 大致题意:由n个珠子,n种颜色,组成一个项链.要求不同的项链数目,旋转后一样的属于同一种,结果模p. n个珠子应该有n种旋转置换,每种置换的循环个数为gcd(i,n).如果直接枚举i,显然不行.但是我们可以缩小枚举的数目.改为枚举每个循环节的长度L,那么相应的循环节数是n/L.所以我们只需求出每个L有多少个i满足gcd(i,n)= n/L,就得到了循环节数为n/L的个数.重点就是求出这样的i的个数. 令cnt = gcd(i,n) =

poj2409 &amp; 2154 polya计数+欧拉函数优化

这两个题都是项链珠子的染色问题 也是polya定理的最基本和最经典的应用之一 题目大意: 用m种颜色染n个珠子构成的项链,问最终形成的等价类有多少种 项链是一个环.通过旋转或者镜像对称都可以得到置换 旋转可以旋转 i=[1,n]次..画图可以看出循环节有gcd(n,i)个 镜像对称的置换画个图也是很容易找的 然后通过polya定理就可以容易的求出等价类的种数了 2409就是这样一个裸题,以下为ac代码 #include <iostream> #include <stdio.h> #

poj 2154 Color 欧拉函数优化的ploya计数

枚举位移肯定超时,对于一个位移i,我们需要的是它的循环个数,也就是gcd(i,n),gcd(i,n)个数肯定不会很多,因为等价于n的约数的个数. 所以我们枚举n的约数,对于一个约数k,也就是循环个数为n/k这样的个数有phi[k]种,证明网上有很多.所以答案就是 phi[k]*(pow(n,n/k)) (k是n的所有约数) 由于约数会很大所以不能打表,只能单个算. 再由于最后要除以n,如果做除法就不能直接取模,所以我们在算每一次pow(n,n/k)的时候,都少乘一个n,这样就相当于除法了. #i

Python3 (函数优化版)简单实现下载某个网站轮播图片

昨日刚刚学习到函数篇,想把函数应用起来,就把前几日写的简单使用函数优化了一下,思路更清晰 import urllib.request import re import os import urllib def getHtml(url): headers = {'User-Agent': 'Mozilla/5.0 (Windows NT 6.1; WOW64; rv:23.0) Gecko/20100101 Firefox/23.0'} redown = urllib.request.Reques

SA:T1编写主函数法和T2Matlab自带的SA工具箱GUI法,两种方法实现对二元函数优化求解——Jason niu

%SA:T1法利用Matlab编写主函数实现对定义域[-5,5]上的二元函数求最优解-Jason niu [x,y] = meshgrid(-5:0.1:5,-5:0.1:5); z = x.^2 + y.^2 - 10*cos(2*pi*x) - 10*cos(2*pi*y) + 20; figure mesh(x,y,z) hold on xlabel('x') ylabel('y') zlabel('z') title('SA:利用SA最优化,定义域[-5,5]上的二元函数z = x^2

遗传算法之函数优化

一.遗传算法简介: 遗传算法是模拟生物在自然环境下的遗传和进化过程的一种自适应的全局优化搜索算法,通过借助遗传学的原理,经过自然选择.遗传.变异等作用机制进而筛选出具有适应性更高的个体(适者生存).遗传算法从20世纪七八十年代的诞生到现在主要集中的适用范围为:NP问题(指存在多项式算法能够解决的非决定性问题).非线性.多峰函数优化和多目标优化问题等等.同时在机器学习.模式识别和神经网络及社会科学中的应用也显得非常出色. 二.遗传算法的实现与目的: 实现 :在计算机上模拟生物的进化过程和基因的操作

汉字转全拼音函数优化方案(SQLServer),值得你看看

函数要求实现功能 select 函数名 ('你好,我是追索') 返回的结果(ni hao , wo shi zhui suo) 解决方案一: 解决方案一 /* 根据汉字获取全拼 1.生成所有读音临时表 2.根据Chinese_PRC_CS_AS_KS_WS 排序获取读音 */ create function dbo.fn_Getquanpin1(@str varchar(100)) returns varchar(8000) as begin declare @re varchar(8000)

poj2054Color polya定理+欧拉函数优化

没想到贱贱的数据居然是错的..搞得我调了一中午+晚上一小时(哦不d飞LJH掉RP毕竟他是BUFF)结果重判就对了五次.. 回归正题,这题傻子都看得出是polya定理(如果你不是傻子就看这里),还没有翻转,就一个旋转,结果我就欢快的打完交上去了.傻子都知道会TLE,n<=1e9啊,O(n)都原地爆炸,那怎么办...一脸懵逼(然后就膜题解了) 可以发现,这题公式就是sigma(gcd(k,n))(k=1~n),然后该怎么优化呢,我(??)发现gcd(k,n)里面肯定有一些k和n的gcd是相同的,那我

iposdb数据库 date函数优化

如下4条SQL,明显是2类SQL语句.2017年5月19号 问题:走了两次全表.select count(*) 活跃商户数量  from (select merchant_code,COUNT(DISTINCT concat(merchant_code,DATE(create_date))) merchantCodeCreateDate from pos_order where DATE(create_date)>='2017-05-12' and DATE(create_date)<='20