斐波那契数列 php实现

⼀、斐波那契数列
  
  本文使用php演示斐波那契数列解法的三种方式, 有一定的演进规律. 阅读时需要自己去体会.
1、暴⼒递归 斐波那契数列的数学形式就是递归的,写成代码就是这样
$start_time = microtime(true);
function fib($n) {
    if ($n === 1 || $n === 2) {
        return 1;
    }
    return fib($n - 1) + fib($n - 2);
}

$f = fib(20);
echo $f;
echo '<hr/>';
$end_time = microtime(true);
var_dump('耗时 = ' . (($end_time - $start_time) * 1000) . 'ms');
var_dump('Now memory_get_usage: ' .  memory_get_usage() . ' b');

输出结果:

6765
string(26) "耗时 = 9.2761516571045ms"
string(29) "Now memory_get_usage: 400112 b"
2、带备忘录的递归解法
$memo_arr = [];
$start_time = microtime(true);
function fib($n) {
    if ($n < 1) {
        return 0;
    }
    // 备忘录全初始化为 0
    $arr = [];
    // 初始化最简情况
    return helper($arr, $n);
}


function helper(&$arr, $n) {
    if ($n === 1 || $n === 2) {
        return 1;
    }
    // 已经计算过
    if ($arr[$n]) {
        //var_dump('$n = ' . $n . '   $arr[$n] = ' . $arr[$n]);
        return $arr[$n];
    } else {
        $arr[$n] = helper($arr, $n - 1) + helper($arr, $n - 2);
    }

    return $arr[$n];
}

$f = fib(20);
echo $f;
echo '<hr/>';
$end_time = microtime(true);
var_dump('耗时 = ' . (($end_time - $start_time) * 1000) . 'ms');
var_dump('Now memory_get_usage: ' .  memory_get_usage() . ' b');

输出结果:

6765
string(26) "耗时 = 0.1218318939209ms"
string(29) "Now memory_get_usage: 402576 b"
3、dp 数组的迭代解法
$start_time = microtime(true);
function fib($n) {
    if ($n === 2 || $n === 1) {
        return 1;
    }
    $prev = 1;
    $curr = 1;
    for ($i = 3; $i <= $n; $i++) {
        $sum = $prev + $curr;
        $prev = $curr;
        $curr = $sum;
    }
    return $sum;
}

$f = fib(20);
echo $f;
echo '<hr/>';
$end_time = microtime(true);
var_dump('耗时 = ' . (($end_time - $start_time) * 1000) . 'ms');
var_dump('Now memory_get_usage: ' .  memory_get_usage() . ' b');

输出结果:

6765
string(28) "耗时 = 0.033855438232422ms"
string(30) "Now memory_get_usage: 400528 b"

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值