- 在线时间
- 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递归程序为例进行比较。
- n# |/ g! d E* M7 E2 b2 ]$ Z& i& q; G. U3 y* k
Matlab 2009a的Fibonacci函数定义:- function k=fib(n)+ C0 V( d$ e; m& d/ |3 y+ b
- if n == 0
+ q4 O w( J# D - k=0;; }\" t% ~1 G# b/ t. I, a0 ~) U t\" M
- return;
/ a j4 \2 v ]2 ^9 S5 B5 M - else if n == 1\" p. \+ X u0 X: m9 a- X
- k=1;
2 f* i9 U m _7 D( r\" L - return;- V, Y7 ?( p x/ S* ~# _1 K
- else
& x1 a) t& ^1 a# ^+ ] - k=fib(n - 1) + fib(n - 2);$ {+ g* v: [0 B0 b
- return;7 i5 Q+ o4 ~) U; H2 H! r E& f
- end4 [. S2 v0 n3 v
- end
复制代码 运行结果:- tic;5 a2 ^& | @8 ]9 r# m4 D/ O\" G; |\" M
- fib(30): K+ n: A7 ]4 v7 z$ m
- toc
. E5 D0 L; Q9 C0 c1 A - 8 ?\" A$ x' z7 M) D- V& N2 [+ t/ k
- ans =
; W* b' P/ l1 J - 832040
$ M7 h* q% l5 }- p% C+ B - 2 W1 s\" s' i, N5 x, f
- Elapsed time is 26.315245 seconds.
复制代码 ===============) F( Q7 s1 x& h
0 f( _5 k& S7 F& `Forcal 9(OpenFC演示)的Fibonacci函数及代码:- SetRealStackMax(1000);
1 U7 A! |; i7 B/ _ - F(n)= which{2 A& T, d- w) Y( o
- n == 0,2 I& T1 Q3 c\" L8 V! _' m# w$ v
- return(0),
\" y. G9 l* F\" K\" K& f7 A$ Y - n == 1,
) y9 M# [1 t& [/ J - return(1),
. B6 e% N- Y\" Q% G - return [F(n - 1) + F(n - 2)]
% @. a2 a! q; o0 }2 j) H% _* Q: l - };
: ]# `( @& e4 o( L& ]( \6 @ - mvar:\" S5 T1 M- w( w, B
- t=sys::clock(),; _4 N' c9 x7 x
- F(30);
; [, ~& c3 n' i& [' h& Z - [sys::clock()-t]/1000;
复制代码 结果:* ~* [+ `/ E) |, ]/ X) c7 x* _
832040./ a# g& G/ o5 r. {
0.391 秒
5 e1 E* l# e& o- Q) E! h/ s8 k2 s
5 Y1 [9 d4 V9 \$ o5 A二者效率相差数十倍。 |
zan
|