- 在线时间
- 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递归程序为例进行比较。6 K1 o' f& ^) D% [
# `' k6 W/ Q) R- |. LMatlab 2009a的Fibonacci函数定义:- function k=fib(n): `3 t7 n9 ]* v. n' R6 F- ?% C9 m: [
- if n == 0
, s3 X, F9 x, R2 W - k=0;
T5 o; W0 H& n- ?\" K% P9 t7 A - return;
% D3 f\" `6 i# E( M - else if n == 1
0 a: y+ y) t& O! I9 Q - k=1;. }; |\" L) F& x8 R
- return;
: Q. |* Z8 K9 U4 g - else
# q; I! }3 P- u& D4 r - k=fib(n - 1) + fib(n - 2);2 M: N6 n# Z9 G* C( n
- return;
3 C3 s: f& d1 V4 ^ o - end# W( c W+ i) G x( I7 P3 p
- end
复制代码 运行结果:- tic;
5 r5 J, M' T5 L0 ?3 ~( p - fib(30)
9 i4 l* z, n2 ^- T/ }- \4 y- Y( f - toc
( [; H- {6 @ V! a\" W
: r% p9 P W\" H8 l# x! L) o7 j- ans =
% f6 r7 u2 u5 I - 832040
0 |- g4 U\" h% X8 C ]& w( P, S- ~- P
6 w# F9 D* l$ C: t/ `' ^+ F5 s9 H2 c- Elapsed time is 26.315245 seconds.
复制代码 ===============
: Y/ S3 G! c! T
7 H. t: f3 ]: k/ L$ ~Forcal 9(OpenFC演示)的Fibonacci函数及代码:- SetRealStackMax(1000);( }% `5 ~6 A( j, c$ p4 s; L- m. @
- F(n)= which{
$ C$ R, J# l/ i7 E - n == 0,4 C0 U' w; v& e- X2 W! v/ E
- return(0),5 o/ d `\" C9 y; S
- n == 1,9 ~9 n$ K2 [ {7 I$ M5 E S
- return(1),4 w( \9 p# }+ U! F5 W1 l
- return [F(n - 1) + F(n - 2)]
\" _/ w: y. V7 E8 e( o - };* F6 J( {& c1 k
- mvar:
. V3 [! ]* o# _& ]6 u - t=sys::clock(),$ X9 E\" L M% R3 _8 g
- F(30);& B# ?7 c. A; E: T1 F
- [sys::clock()-t]/1000;
复制代码 结果:
$ b+ v& Z- L8 ?+ t832040.6 |# v, |# g8 ]7 m7 d1 h
0.391 秒
2 i- }5 ?& O3 p7 s4 g! i& Y- H* o7 |- r. i) }6 S
二者效率相差数十倍。 |
zan
|