用“类”来代替“递归方法”,用php举例。

王朝php·作者佚名  2006-01-09
宽屏版  字体: |||超大  

/***************************

* author : 大龄青年

* email : wenadmin@sina.com

* from: http://blog.csdn.net/hahawen

* 转载请保留这部分信息,谢谢

***************************/

问题:一个楼梯有n个台阶,每次上一个或两个台阶,共有多少种上法, 每种走法的步骤是什么样的?

这个简单问题,我们通常的方法是写一个递归调用,简单明了。但是,这里通过类的叠加来实现,虽然本身没有太大的意义,但是这种设计的用途还是满多的,可以自己考虑考虑。

<?php

//一个楼梯有n个台阶,每次上一个或两个台阶,共有多少种上法, 每种走法的步骤是什么样的.

define('TOTLE_STEP', 10);

$p = '';

$obj = new step($p, 0, 0);

$obj->go();

class step{

var $parent;

var $count;

var $step;

var $son1;

var $son2;

function step(&$parent, $step, $count){

$this->parent = &$parent;

$this->step = $step;

$this->count = $count + $step;

}

function go(){

if($this->count==TOTLE_STEP)

$this->callback();

if($this->count<=TOTLE_STEP-1){

$this->son1 = new step($this, 1, $this->count);

$this->son1->go();

}

if($this->count<=TOTLE_STEP-2){

$this->son2 = new step($this, 2, $this->count);

$this->son2->go();

}

}

function callback($str=''){

if($this->parent!=null){

$str = $this->step.$str;

$this->parent->callback('--'.$str);

}else{

echo $str.'<br>';

}

}

}

?>

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
© 2005- 王朝网络 版权所有