QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 9746|回复: 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递归程序为例进行比较。$ Q& @3 x' l' m+ G, I: }" p# l
    , B" \7 X  W& t3 K0 M
    Matlab 2009a的Fibonacci函数定义:
    1. function k=fib(n)( @7 }& Z! d% P! {4 {8 V; T2 o
    2. if n == 00 h% ~( i4 v7 K: N' ?! B
    3.   k=0;9 Z! b  p: S+ G$ I7 r. x\" a
    4.   return;
      , a/ h( s: }, E
    5. else if n == 1
      ' b5 m7 }( @  b8 {7 C
    6.   k=1;7 s$ }2 m- p! p
    7.   return;7 _8 E\" M, b0 N6 D* i6 U
    8. else+ Z; N  K0 E2 j! w1 t. Z1 b0 A
    9.   k=fib(n - 1) + fib(n - 2);% s- \: A8 A+ I: _
    10.   return;
      ' ^% r1 _, \, t\" X\" N1 M0 o) ]% n
    11. end
      - t. i$ \& Q3 v% \1 }! z2 W
    12. end
    复制代码
    运行结果:
    1. tic;
      8 }- N, U5 ^7 Y0 V; Q# ^' ]3 E6 F
    2. fib(30), A0 y6 Z1 q% v
    3. toc
      ; i. j\" D0 U2 n3 Z\" L

    4. # j5 N8 v0 K1 p. M# a* U
    5. ans =
      6 Z* g\" g( ^0 X2 G) K$ P
    6.       832040
      # L\" s( H' [9 [2 p) T- |
    7. 0 S% L. V/ _) K3 g\" D4 }
    8. Elapsed time is 26.315245 seconds.
    复制代码
    ===============
    / @1 l- n& h" o
    & @' B: Q8 b# L4 }- @2 l/ wForcal 9(OpenFC演示)的Fibonacci函数及代码:
    1. SetRealStackMax(1000);
      $ |3 ?9 @, J6 \\" I' `0 L
    2. F(n)= which{5 r5 n% J* }5 ]8 B
    3.     n == 0,
      4 e  s3 _3 Z7 }  @
    4.         return(0),3 a9 ^1 {) N. J2 ^
    5.     n == 1,# ~6 c. _( `) S: _
    6.         return(1),
      & [) e7 A% C$ Q/ @# ]4 j$ k6 K
    7.     return [F(n - 1) + F(n - 2)]9 `* m2 i* S( D
    8. };* r' i* Y/ t8 b/ b' w) o* s9 {$ k& ~8 [
    9. mvar:  F. c\" x( G0 |\" ^3 Q! N
    10. t=sys::clock(),
      \" w) k\" S! E3 F  j; g/ S4 g5 L
    11. F(30);2 n+ g: o& U; y
    12. [sys::clock()-t]/1000;
    复制代码
    结果:
      t9 A( Y) B4 m  Z8 S. ~832040.
    + V& w; d  k& y/ F7 w# U" C. E0.391  秒
    $ \( M- o/ v5 u  j" J. U3 E7 y+ ]: F+ ~8 A" f+ e3 f
    二者效率相差数十倍。
    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-6-12 22:44 , Processed in 0.463655 second(s), 68 queries .

    回顶部