用PHP迭代器来实现一个斐波纳契数列
2014-10-13 14:18
204 查看
斐波纳契数列通常做法是用递归实现,当然还有其它的方法。这里现学现卖,用PHP的迭代器来实现一个斐波纳契数列,几乎没有什么难度,只是把类里的next()方法重写了一次。注释已经写到代码中,也是相当好理解的。
view source
print?
程序运行结果:
view source
print?
view source
print?
01 | /** |
02 | * @author 简明现代魔法 http://www.nowamagic.net |
03 | */ |
04 | class Fibonacci implements Iterator { |
05 | private $previous =1; |
06 | private $current =0; |
07 | private $key =0; |
08 |
09 | public function current() { |
10 | return $this ->current; |
11 | } |
12 |
13 | public function key() { |
14 | return $this ->key; |
15 | } |
16 |
17 | public function next() { |
18 | // 关键在这里 |
19 | // 将当前值保存到 $newprevious |
20 | $newprevious = $this ->current; |
21 | // 将上一个值与当前值的和赋给当前值 |
22 | $this ->current += $this ->previous; |
23 | // 前一个当前值赋给上一个值 |
24 | $this ->previous = $newprevious ; |
25 | $this ->key++; |
26 | } |
27 |
28 | public function rewind () { |
29 | $this ->previous =1; |
30 | $this ->current =0; |
31 | $this ->key =0; |
32 | } |
33 |
34 | public function valid() { |
35 | return true; |
36 | } |
37 | } |
38 |
39 | $seq = new Fibonacci; |
40 | $i =0; |
41 | foreach ( $seq as $f ) { |
42 | echo "$f " ; |
43 | if ( $i ++ ===15) break ; |
44 | } |
view source
print?
1 | 0 1 1 2 3 5 8 13 21 34 55 89 144 233 377 610 |
相关文章推荐
- 用PHP迭代器来实现一个斐波纳契数列(转)
- 用PHP迭代器来实现一个斐波纳契数列
- 用PHP迭代器来实现一个斐波纳契数列
- PHP迭代器实现斐波纳契数列的函数
- PHP迭代器实现斐波纳契数列的函数
- 一个真正符合中国国情的工作流设计参考(包括PHP实现)
- 一个真正符合中国国情的工作流设计参考(包括PHP实现)
- PHP实现一个简单的无刷新聊天室
- 一个简单的php实现的MySQL数据浏览器
- 万恶的单线程!!怎样才能实现一个真正的多线程的php socket server啊!!!
- 一个真正符合中国国情的工作流设计参考(包括PHP实现)
- 一个简单的php实现的MySQL数据浏览器
- js 数组实现一个类似ruby的迭代器
- 一个用php实现密码强度检测的类
- 一个真正符合中国国情的工作流设计参考(包括PHP实现)
- 一个真正符合中国国情的工作流设计参考(包括PHP实现)
- 一个真正符合中国国情的工作流设计参考(包括PHP实现)
- 一个用php实现的获取URL信息的类
- 一个真正符合中国国情的工作流设计参考(包括PHP实现)