QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 8492|回复: 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递归程序为例进行比较。
    , w2 d! l" g! ]8 E' b) v2 x% Z- E+ H# U, V  a" o
    Matlab 2009a的Fibonacci函数定义:
    1. function k=fib(n)9 Z1 k$ {* g2 }: X8 @% F  k
    2. if n == 0
      . U& t, X\" O$ Z  K5 x
    3.   k=0;5 L6 C2 {9 A7 F; X1 u9 |% |' r0 x1 l
    4.   return;
      / J+ W4 n6 p% ?1 z, r\" @
    5. else if n == 18 R8 {+ i/ Q7 z; Z( Z2 K. K/ f
    6.   k=1;
      8 c9 \. U, l1 V% V
    7.   return;
      + O. k; e4 b\" \* B% r1 _) \/ T
    8. else
      0 z% s( [: t3 _# I- O  z2 @. T
    9.   k=fib(n - 1) + fib(n - 2);( a! j  N  m8 T) \7 Y
    10.   return;, {5 E  u' `+ h% v\" {0 h. j
    11. end0 W2 X: j0 f7 m7 O* B
    12. end
    复制代码
    运行结果:
    1. tic;
      ( ~4 f2 l5 Z\" k9 H
    2. fib(30)& D5 e$ X. z* b8 m; F/ F) `9 ?
    3. toc
      \" Y1 r\" e& @0 Y8 e

    4. , p) b/ m  V4 S- e2 [
    5. ans =
      2 G; b2 j9 l2 N7 e5 |- R, E2 S
    6.       832040% g8 M5 h7 ]/ u4 A! W+ q0 z

    7. 0 |2 q) W7 \7 V6 a- s
    8. Elapsed time is 26.315245 seconds.
    复制代码
    ===============
    + G& y' A+ d6 H" W+ Y4 |
    8 _# \6 t' o: I/ e# j8 q# j" YForcal 9(OpenFC演示)的Fibonacci函数及代码:
    1. SetRealStackMax(1000);. v( y& W' }7 @9 l7 y
    2. F(n)= which{* _$ i! K4 E$ q\" e
    3.     n == 0,
      2 G- d8 Y% l$ l, Q7 c
    4.         return(0),
        A\" J1 X8 R; l9 J\" p/ L
    5.     n == 1,
      7 ~9 h' L5 o# X5 }
    6.         return(1),+ T/ C; b6 J# G/ s# C
    7.     return [F(n - 1) + F(n - 2)]4 }: o7 C) j: `) ^1 T3 V1 p
    8. };
      . y1 Y6 q! K* `2 J) E$ Y
    9. mvar:) N! P9 }7 ~; e$ l, j0 t7 s
    10. t=sys::clock(),# ]) f' I  p4 a; n0 ~\" i! q  U
    11. F(30);
        F. z3 L8 a/ n* x# t\" J% U& l: x
    12. [sys::clock()-t]/1000;
    复制代码
    结果:. x. ]- `% r. w' ?$ |& `
    832040.; P+ i& l7 D" i! Y6 L! L# n$ t
    0.391  秒
    5 P2 b9 u' l& d2 D  {, b- g, C
    ) d* Q. P9 S: Q. D! @, J二者效率相差数十倍。
    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, 2024-4-26 07:46 , Processed in 0.346635 second(s), 67 queries .

    回顶部