php专区

 首页 > php专区 > PHP进阶 > 算法 > 上楼梯有几种走法问题

上楼梯有几种走法问题

分享到:
【字体:
导读:
         摘要:假设一个楼梯有N阶台阶,人每次最多可以跨M阶。例如楼梯总共有3个台阶,人每次最多跨2个台阶,也就是说人每次可以走1个,也可以走2个,但最多不会超过2个,那么楼梯总共有这么3种走法。现在要求用程序实现计算台阶的所有走法的总数。其实就是个斐波那契数列。 ...

上楼梯有几种走法问题

假设一个楼梯有 N 阶台阶,人每次最多可以跨 M 阶。例如楼梯总共有3个台阶,人每次最多跨2个台阶,也就是说人每次可以走1个,也可以走2个,但最多不会超过2个,那么楼梯总共有这么几种走法:

    
①:1 1 1
②:1 2
③:2 1

现在要求用程序实现计算台阶的所有走法的总数。

其实就是个斐波那契数列。下面是用递归方法来解决:

';
}
?>

程序运行结果:

1
2
3
5
8
13
21
34
55

非递归方法:

function up($n)
{
	$a = array(1, 2);
	for($i = 3; $i <= $n; $i++){
		$a[$i] = $a[$i-1] + $a[$i-2];
	}
	print_r($a);
}
up(10);

如果说要展示出所有的情况的递归方法:

function up_out($n)
{
	if($n == 1)
		return array('1 ');
	else if($n == 2)
		return array('1 1 ', '2 ');
	return array_merge(lian(up_out($n-1),'1 '), lian(up_out($n-2), '2 '));
}
function lian($a1, $a2)
{
	foreach($a1 as &$a1_v) {
		$a1_v = $a1_v . $a2;
	}
	return $a1;
}
print_r(up_out(10));

展示所有情况的非递归方法:

function up_out($n)
{
	$re = array(array(0), array('1 '), array('1 1 ', '2 '));
	for($i = 3; $i 												

本文地址:http://www.nowamagic.net/librarys/veda/detail/995,欢迎访问原出处。

上楼梯有几种走法问题
分享到:
如何不使用额外变量来交换两变量
如何不使用额外变量来交换两变量 交换两个变量,通常我们的做法是(尤其是在学习阶段):定义一个新的变量,借助它完成交换。代码如下: int a,b; a=10; b=15; int t; t=a; a=b; b=t; 这种算法易于理解,特别适合帮助初学者了解计算机程序的特点,是赋值语句的经典应用。在实际软件开发当中,此算...
JavaScript各种排序的性能比较
JavaScript各种排序的性能比较 排序是经常使用的编程例子,在JavaScript里各种排序的性能又如何呢?每个浏览器测试得出的数据会不一样。比如我用chrome 测试 一般快速排序都会最快,IE 则根据数组长度有可能希尔最快。 不要用太大数据去测试冒泡排序(浏览器崩溃了我不管)。 [4,2,5,6,8,9,7,0,1,3] ...
  •         php迷,一个php技术的分享社区,专属您自己的技术摘抄本、收藏夹。
  • 在这里……