- 在线时间
- 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递归程序为例进行比较。
$ ?% `5 e2 W& t+ E/ v$ T$ ]3 ]/ m1 E W# a, ]
Matlab 2009a的Fibonacci函数定义:- function k=fib(n)
- H1 h: e+ p- w- Z0 \ - if n == 0
: I! s7 Z\" X5 ^. n y9 K% f - k=0;
: f7 {7 V* ^8 p1 B, a# c$ u) `. I - return;
) U6 u4 x6 S( n' m8 \1 l - else if n == 1. @3 Y5 M- m* c; \! {
- k=1;
\" v- I7 i- G4 D' \& `( b - return;
9 `6 P9 y% Z\" g! B! g& j/ ^) U - else$ c3 `1 [+ o1 t( d4 [- n \
- k=fib(n - 1) + fib(n - 2);- E$ ` X6 M8 [( \$ w$ h
- return;
7 L. m# v5 M, t6 E U2 K, A - end
, w' U. h; o9 [; F - end
复制代码 运行结果:- tic;# s d! O2 Z# N7 c+ W6 m2 Z7 B7 t7 N
- fib(30)
. W% F7 b$ k C# V, x - toc, V1 a5 s4 P& l: F% `6 B- a
- & c- h# y; Y$ r4 _/ B\" U8 z
- ans =
$ ?4 ?! C2 y\" R/ f8 X - 832040
8 E; @& t) l6 y; U+ }1 O - 5 t9 k* W% ~; L0 e; C
- Elapsed time is 26.315245 seconds.
复制代码 ===============6 Z/ X: ]; w" q- p
3 q2 q3 A2 j/ PForcal 9(OpenFC演示)的Fibonacci函数及代码:- SetRealStackMax(1000);
/ G\" L) _' o6 `! i - F(n)= which{
9 @\" Q0 u0 e$ J% }6 j3 E - n == 0,
/ a, F- @8 \+ o0 a5 }& K. l9 E% o) ~ - return(0),
, Z$ r/ q0 S$ a\" K3 w+ x U - n == 1,
4 ` w! Z9 ]# u$ u# Q7 J4 @ - return(1),
|) ~3 t3 @/ [. l - return [F(n - 1) + F(n - 2)]* U( U0 D; s; g8 P- J9 d
- };
x) W' ^ `2 e3 L - mvar:6 `\" u$ o8 J0 `1 ?2 O0 P
- t=sys::clock(),
# F: o1 a* d; G# L. J0 w* V+ g - F(30);
- }3 k, ]3 ?& P# [3 J9 F2 W6 T - [sys::clock()-t]/1000;
复制代码 结果:
% R9 R9 }5 F8 O; m; k7 _2 ]832040.& G7 A/ u2 P3 X# j7 x' t+ L
0.391 秒9 y; ]; B& I* z* e
5 E! \7 R, s' S: D: d) }0 u# S
二者效率相差数十倍。 |
zan
|