QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 9664|回复: 2
打印 上一主题 下一主题

极限测试之Matlab与Forcal的递归函数调用效率

[复制链接]
字体大小: 正常 放大
forcal 实名认证       

45

主题

3

听众

282

积分

升级  91%

  • TA的每日心情
    难过
    2012-8-27 18:22
  • 签到天数: 1 天

    [LV.1]初来乍到

    跳转到指定楼层
    1#
    发表于 2011-7-31 10:08 |只看该作者 |倒序浏览
    |招呼Ta 关注Ta
    以Fibonacci递归程序为例进行比较。
    - n# |/ g! d  E* M7 E2 b2 ]$ Z& i& q; G. U3 y* k
    Matlab 2009a的Fibonacci函数定义:
    1. function k=fib(n)+ C0 V( d$ e; m& d/ |3 y+ b
    2. if n == 0
      + q4 O  w( J# D
    3.   k=0;; }\" t% ~1 G# b/ t. I, a0 ~) U  t\" M
    4.   return;
      / a  j4 \2 v  ]2 ^9 S5 B5 M
    5. else if n == 1\" p. \+ X  u0 X: m9 a- X
    6.   k=1;
      2 f* i9 U  m  _7 D( r\" L
    7.   return;- V, Y7 ?( p  x/ S* ~# _1 K
    8. else
      & x1 a) t& ^1 a# ^+ ]
    9.   k=fib(n - 1) + fib(n - 2);$ {+ g* v: [0 B0 b
    10.   return;7 i5 Q+ o4 ~) U; H2 H! r  E& f
    11. end4 [. S2 v0 n3 v
    12. end
    复制代码
    运行结果:
    1. tic;5 a2 ^& |  @8 ]9 r# m4 D/ O\" G; |\" M
    2. fib(30): K+ n: A7 ]4 v7 z$ m
    3. toc
      . E5 D0 L; Q9 C0 c1 A
    4. 8 ?\" A$ x' z7 M) D- V& N2 [+ t/ k
    5. ans =
      ; W* b' P/ l1 J
    6.       832040
      $ M7 h* q% l5 }- p% C+ B
    7. 2 W1 s\" s' i, N5 x, f
    8. Elapsed time is 26.315245 seconds.
    复制代码
    ===============) F( Q7 s1 x& h

    0 f( _5 k& S7 F& `Forcal 9(OpenFC演示)的Fibonacci函数及代码:
    1. SetRealStackMax(1000);
      1 U7 A! |; i7 B/ _
    2. F(n)= which{2 A& T, d- w) Y( o
    3.     n == 0,2 I& T1 Q3 c\" L8 V! _' m# w$ v
    4.         return(0),
      \" y. G9 l* F\" K\" K& f7 A$ Y
    5.     n == 1,
      ) y9 M# [1 t& [/ J
    6.         return(1),
      . B6 e% N- Y\" Q% G
    7.     return [F(n - 1) + F(n - 2)]
      % @. a2 a! q; o0 }2 j) H% _* Q: l
    8. };
      : ]# `( @& e4 o( L& ]( \6 @
    9. mvar:\" S5 T1 M- w( w, B
    10. t=sys::clock(),; _4 N' c9 x7 x
    11. F(30);
      ; [, ~& c3 n' i& [' h& Z
    12. [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
    转播转播0 分享淘帖0 分享分享0 收藏收藏0 支持支持0 反对反对0 微信微信

    0

    主题

    0

    听众

    3

    积分

    升级  60%

    该用户从未签到

    回复

    使用道具 举报

    alair005        
    头像被屏蔽

    0

    主题

    4

    听众

    782

    积分

    升级  45.5%

  • TA的每日心情

    2012-2-7 08:08
  • 签到天数: 5 天

    [LV.2]偶尔看看I

    提示: 作者被禁止或删除 内容自动屏蔽
    回复

    使用道具 举报

    您需要登录后才可以回帖 登录 | 注册地址

    qq
    收缩
    • 电话咨询

    • 04714969085
    fastpost

    关于我们| 联系我们| 诚征英才| 对外合作| 产品服务| QQ

    手机版|Archiver| |繁體中文 手机客户端  

    蒙公网安备 15010502000194号

    Powered by Discuz! X2.5   © 2001-2013 数学建模网-数学中国 ( 蒙ICP备14002410号-3 蒙BBS备-0002号 )     论坛法律顾问:王兆丰

    GMT+8, 2026-4-20 08:15 , Processed in 0.390523 second(s), 67 queries .

    回顶部