QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 9745|回复: 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递归程序为例进行比较。
    / I# n3 N) B0 v# }
    / E/ P3 U# E  }" i- V% I# dMatlab 2009a的Fibonacci函数定义:
    1. function k=fib(n)
      \" J& L\" [* \1 z
    2. if n == 0
      5 @\" z2 g7 R+ A0 Z
    3.   k=0;' y! H\" s9 G! S. o7 _
    4.   return;; Y) d\" |/ h% s. @
    5. else if n == 1( g1 |3 M7 q) G, e
    6.   k=1;1 f' b+ W# I6 C) d: R* n5 h  Y
    7.   return;
      ( E1 C, A, _& e& {5 f
    8. else% {$ N4 a, T* D
    9.   k=fib(n - 1) + fib(n - 2);& P5 V4 Q, h8 }% l( ~0 O) y
    10.   return;- o6 b# ^\" a% Z. k- f6 d, J2 j
    11. end+ I# W5 A  q% I  {6 t8 \! V
    12. end
    复制代码
    运行结果:
    1. tic;
      4 x1 G* Q3 _2 L) e) R4 q
    2. fib(30)4 w& J& Z0 `( I8 x- M
    3. toc, L- j  _6 o% s# V- j
    4. 3 p3 y* h% U! t: G
    5. ans =
      ; p\" \* l, a2 ?; c5 v$ a- q$ c
    6.       832040\" V/ r2 L7 y0 p5 q3 N/ f- v  Q8 S5 Z

    7. ( ~( A- d9 r9 J) G4 D+ K
    8. Elapsed time is 26.315245 seconds.
    复制代码
    ===============+ h8 s" s$ n0 g# o7 f0 j% E" A

    8 ^- T0 m( a9 @+ l! j  Z& xForcal 9(OpenFC演示)的Fibonacci函数及代码:
    1. SetRealStackMax(1000);
      - M& E\" y5 T1 _9 g7 L
    2. F(n)= which{* E/ u0 r! a* l. F: I* D\" A
    3.     n == 0,: o+ l# v- _+ S+ i7 M. `
    4.         return(0),
        w  V( j9 j\" g0 n. z2 P) @
    5.     n == 1,
      3 w\" g! i; q3 s/ p- M
    6.         return(1),
      . i$ |6 P2 V& V- x  O5 s! i
    7.     return [F(n - 1) + F(n - 2)]
      ! \# a, X1 s# \# q
    8. };
      ) {/ O# G5 A# J+ }/ o
    9. mvar:8 R# |* u9 w% Z& @/ l
    10. t=sys::clock(),  @  U& o0 P\" f# E  \
    11. F(30);0 H+ M% `# w) D( i# c
    12. [sys::clock()-t]/1000;
    复制代码
    结果:
    / c; r% {3 _( O. D7 ?& _832040.* u, Y6 A3 K/ w
    0.391  秒" r5 d: u8 \" D3 \$ X% M
    4 M# O2 A/ X) t+ h( ^9 }! W
    二者效率相差数十倍。
    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 20:49 , Processed in 0.558307 second(s), 69 queries .

    回顶部