- 在线时间
- 13 小时
- 最后登录
- 2013-12-8
- 注册时间
- 2010-5-13
- 听众数
- 3
- 收听数
- 0
- 能力
- 0 分
- 体力
- 399 点
- 威望
- 11 点
- 阅读权限
- 30
- 积分
- 282
- 相册
- 0
- 日志
- 0
- 记录
- 0
- 帖子
- 97
- 主题
- 45
- 精华
- 0
- 分享
- 0
- 好友
- 1
升级   91% TA的每日心情 | 难过 2012-8-27 18:22 |
|---|
签到天数: 1 天 [LV.1]初来乍到
 |
以Fibonacci递归程序为例进行比较。
' \& s% g" s% W( X0 W7 R+ S2 F1 f7 {6 p" N6 Y6 c
Matlab 2009a的Fibonacci函数定义:- function k=fib(n)4 v+ k8 l2 C2 l$ L9 v
- if n == 09 l\" j3 Z& C0 C\" D7 t# q
- k=0;
2 N6 w/ C! a5 z% T, ^ - return; d3 s0 Y- `6 i% F% i. o
- else if n == 1' ?\" I D$ v+ ?0 D3 J5 _8 [
- k=1;1 ]' k9 p* G# j) Q* J: _9 r- N+ w
- return;
3 @% g8 z; M\" ?3 c, H/ U - else* C. A; n8 W\" G; E
- k=fib(n - 1) + fib(n - 2);% }/ E& n3 z\" y/ E9 ?1 q3 I$ k2 C
- return;
8 i& k6 K: ~( J3 e0 w% O/ N' k' @ - end: ]9 R: i8 V+ {/ i5 c1 j. b. t3 r
- end
复制代码 运行结果:- tic;
\" p6 d\" W# _! H% Q' d+ R - fib(30)
$ _! r) R! Q- V4 ? - toc+ R& `, S, r8 `* [- p' e' M
% u) X# {7 d\" b1 V6 D6 I% g1 l- b2 `- ans =1 Y j$ t) F* z2 ~
- 832040& y/ G3 c7 V/ q- ~. o
- ! d3 \6 u) d: A7 ~) \
- Elapsed time is 26.315245 seconds.
复制代码 ===============
5 E9 \2 b5 U; C% q% ?) O5 Y* A8 A, K
4 i) W+ ?: f5 b# m; J AForcal 9(OpenFC演示)的Fibonacci函数及代码:- SetRealStackMax(1000);
# [4 [\" T5 U) W+ g9 z( D - F(n)= which{
; \1 X8 z: Y# v' ?/ K4 r6 c - n == 0,9 e- B4 G# c L+ i
- return(0),. W\" _. M% c, F
- n == 1,6 }- L0 U! h7 v, j\" f$ l& _
- return(1),7 g( [% a7 O% t/ |. ^ m4 m* B
- return [F(n - 1) + F(n - 2)]
) {& v# u! K8 R- J% f: m u- H8 T5 D: Y! ~ - };* r\" g7 K\" J0 i\" ?- u+ c( ^
- mvar:
0 ~8 `1 `' X5 i _ - t=sys::clock(),
+ j: j. A# m\" \- k - F(30);$ t3 S. Q5 x/ i! C
- [sys::clock()-t]/1000;
复制代码 结果:
: h3 L7 [2 l0 Q3 B- G2 o3 G832040.
, p; K2 ]. O& D% x* V8 }' A. ~; y' V0.391 秒
) a% _6 W' Q8 J9 I* A$ g9 o6 L2 T. ? G+ E5 N& N4 `1 v0 d
二者效率相差数十倍。 |
zan
|