QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 9480|回复: 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; W2 S8 l' ?2 p
    % b0 R8 _1 M, u) aMatlab 2009a的Fibonacci函数定义:
    1. function k=fib(n)
      $ Q5 t/ b' Y/ d: J) x0 T
    2. if n == 0
      $ t, }; P7 B; D- A& `, B
    3.   k=0;
      ) [$ W. m: F& D3 m) `
    4.   return;) t1 O' ^3 L& T; V9 N) i
    5. else if n == 1, G\" y/ d7 U0 b\" d* ?# |4 ?9 p
    6.   k=1;$ a3 B* c7 Q, }+ ^
    7.   return;
      % f0 i$ r& I, c5 n4 W% I, {
    8. else) J9 ^( D. A0 i$ E- {
    9.   k=fib(n - 1) + fib(n - 2);1 Q: [# ]) |0 I6 U) `! M- \8 Y) r
    10.   return;0 |  |$ C2 E) @0 a; u0 W/ a
    11. end
      . b5 ~# n+ O- }6 s) C
    12. end
    复制代码
    运行结果:
    1. tic;
      4 T5 g, @* @) j3 f! O9 ^( x' X\" P
    2. fib(30)& U) A, r  `) x4 e4 g
    3. toc
        s+ H; d6 Z8 y2 H
    4. . ~7 X: b+ r( q/ r9 @7 p% ^3 \
    5. ans =* \, X. i, K4 I! j7 f
    6.       832040
      9 @! s' Z$ F4 \: {9 Y

    7. 4 r\" y% K$ S8 \
    8. Elapsed time is 26.315245 seconds.
    复制代码
    ===============0 ?4 _* c; _6 `% T2 X
    # u4 `* q" k0 r" ?5 u# Q) v
    Forcal 9(OpenFC演示)的Fibonacci函数及代码:
    1. SetRealStackMax(1000);
      : w\" ?8 c4 k! ?( \) ?' w- o
    2. F(n)= which{
      1 i. d; u4 L2 L- Z  Z6 c3 E' N' w
    3.     n == 0,
      / x( F. f\" A- ?6 d
    4.         return(0),2 h$ _! T* R( s) C) y7 v) ^4 M
    5.     n == 1,
      4 K/ [6 s& Z7 v- q
    6.         return(1),
      : t, m$ f' m% v! [4 L
    7.     return [F(n - 1) + F(n - 2)]
      - D8 `  N0 R# a5 M) h
    8. };
      ) ~' t+ _* w8 P  `\" S: h
    9. mvar:0 j7 S! r- v5 Q+ @& [3 V
    10. t=sys::clock(),8 [# q$ H8 {; d+ p  u3 l6 H
    11. F(30);
      5 N4 _/ g1 \2 l0 g, c* ^
    12. [sys::clock()-t]/1000;
    复制代码
    结果:
    $ d& Z" z8 N; F/ A832040.
    4 P& e. a+ C5 k0.391  秒& c, P* J. {) m( }0 b% G
    ! o/ ?) `5 l7 I2 ^. o/ s
    二者效率相差数十倍。
    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, 2025-11-15 22:15 , Processed in 0.502538 second(s), 67 queries .

    回顶部