经典算法 - 斐波那契

斐波那契数列:1 1 2 3 5 8 …
满足要求:当前项 = 前第一项 + 前第二项
现在要求输入一个整数n,请你输出斐波那契数列的第n项(从0开始,第0项为0)。
编写一个类,在类中编写两个静态方法,分别使用递归和非递归方法实现上述要求

class metchs{

	public static function fun($n)
	{
		static $array = array();
		if($n <= 0) return 0;
		if($n == 1 || $n ==2 ) return 1 ;
		$array['1'] = 1 ; 
		$array['2'] = 1 ;
		for($i=3; $i<=$n; $i++)
		{
			$array[$i] = $array[$i-1]+$array[$i-2] ;
		}
		return $array[$n];
		
	}
	public static function fun1($n)
	{
		if($n <= 0) $m = 0;
		if($n == 1 || $n ==2 ) $m = 1 ;
		if($n>= 3)
		{
			$m = self::fun1($n-1)+self::fun1($n-2);
		}
		return $m ;


	}
	

}

$n = 20;
echo metchs::fun($n);
echo metchs::fun1($n);
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值