- 在线时间
- 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递归程序为例进行比较。
( o) V! w# |8 y# N, }0 \: d. x3 |) |
+ _! y: u* W* w% |7 AMatlab 2009a的Fibonacci函数定义:- function k=fib(n)1 c5 _$ N( J, C) v9 D$ ?* Y( Q6 K# L4 W
- if n == 0
8 e v8 Q5 }6 x) m! I$ q( w+ O - k=0;
0 z+ z5 M! R, a+ E9 u J% u; ~& g - return;1 a2 u9 q) N8 ~7 o+ A3 t
- else if n == 1
) D. W& N* g y, _& [ n - k=1;
$ B: `; z! z3 q\" K. O) S( M! P - return;4 A* c! U9 x$ Z: `3 b; c7 [
- else
( p6 h+ A# ]4 O/ B8 ?/ A5 D, I9 I - k=fib(n - 1) + fib(n - 2);
9 E' V2 ~4 a- F1 ~\" K - return;
; u\" c; B$ Q! X9 q4 z - end( y. t1 S/ c$ g
- end
复制代码 运行结果:- tic;( v) R& [$ t, V- r9 W; U
- fib(30)\" K, g4 t* _- i9 ?
- toc6 M+ D' ], D( I) i- |6 C
: @4 F/ ]. j$ B' l0 N- ans =/ K8 C. }$ z2 T0 \, M. e
- 832040: C }% L- A8 M: P( y7 S6 y5 Q
- 5 U+ j: }7 a: K9 m( F: ? K6 ^$ x5 B
- Elapsed time is 26.315245 seconds.
复制代码 =============== Q8 t J- \- ?$ F
8 h; k z6 u- h1 }Forcal 9(OpenFC演示)的Fibonacci函数及代码:- SetRealStackMax(1000);
G9 d4 Z2 L# A8 m\" w/ Y* Q: x - F(n)= which{3 C& h% } k( o0 a
- n == 0,( P6 f. K- S) ]3 z\" S+ O0 j- s
- return(0), n) H, a2 L3 \6 ^
- n == 1,8 \) u% N% t5 W
- return(1),
1 D4 z) o\" ^2 v: T% r* y. R - return [F(n - 1) + F(n - 2)]* k+ |\" s7 V. h* y- N
- };
8 Z2 u4 r' X9 f: l - mvar:
' t* J0 l# N\" D3 P2 } - t=sys::clock(),; l# M$ r( |1 h' T5 I
- F(30);- M6 s2 M! [: Y\" q- j2 A
- [sys::clock()-t]/1000;
复制代码 结果:
! x: U5 T1 \5 _" Z T8 [832040.: G( m- x% w5 Y+ Q2 d. k" b
0.391 秒
# X( E) [! I+ z; ]# U5 I
u4 P4 N; M$ |二者效率相差数十倍。 |
zan
|