QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 9665|回复: 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递归程序为例进行比较。
    1 C$ t3 U" X  ^2 |2 |: j+ X/ I6 V5 l$ ~, f2 T8 H% o7 P
    Matlab 2009a的Fibonacci函数定义:
    1. function k=fib(n)2 D: [* ]* f( \* g
    2. if n == 0
      ; s* J& z2 [; q2 _
    3.   k=0;( _' A4 t\" j! t/ r
    4.   return;
      # d& X# j8 [% o- {8 d% u( x& M
    5. else if n == 1! S0 M# u\" [) f! Y: n
    6.   k=1;
      + C2 I! t% F\" t$ u# h
    7.   return;
      8 w1 X' J! d5 J( |; F
    8. else, E0 ]' [* O6 k% U2 Z( U
    9.   k=fib(n - 1) + fib(n - 2);: v0 V$ R, R& G+ ~. ]
    10.   return;; e, I7 [2 \4 M1 W
    11. end! k3 _6 w/ @8 P' ^/ g# P# C0 j\" W' p
    12. end
    复制代码
    运行结果:
    1. tic;$ F4 J. d, M1 P5 _/ @
    2. fib(30)
      2 o1 E1 u- S) }\" S* E7 m* W
    3. toc* H5 v3 Y& T6 N4 ]\" o& O5 A

    4. & d; y4 C, d8 k* T5 G/ S3 b
    5. ans =! H+ u. y. K- @\" J% p2 j
    6.       832040
        Z; c& e6 u. B
    7. 9 X# n8 ?1 F4 t# C% }
    8. Elapsed time is 26.315245 seconds.
    复制代码
    ===============
    * ], S4 b2 F# W& A, _0 s/ F; \, q' i$ r8 g  \$ Q. v; ^
    Forcal 9(OpenFC演示)的Fibonacci函数及代码:
    1. SetRealStackMax(1000);7 ]' C) `\" ^! R, j6 z3 [7 c+ F+ R
    2. F(n)= which{
      # k* ?/ U& {\" E4 T$ I/ E
    3.     n == 0,
      5 U% R/ \5 v7 k
    4.         return(0),
      8 ^0 k\" G- U  v& @
    5.     n == 1,
      6 k1 s; v; P; O+ g+ }' I& A
    6.         return(1),+ w2 @0 d) w! J( r* \3 u: f
    7.     return [F(n - 1) + F(n - 2)]# _; h- F6 H4 M( |( i
    8. };
      & N) _& n3 i\" d, i% k) R+ }6 C; L
    9. mvar:
      $ h\" D* V* K6 K5 R- h2 d+ c
    10. t=sys::clock(),
      6 D( W4 x3 t2 v  }, i
    11. F(30);
      5 A  T7 X9 O4 ~\" C. R5 G5 D
    12. [sys::clock()-t]/1000;
    复制代码
    结果:
    3 d) R; `2 T4 }, p8 L4 j) O* U832040./ O9 ?' {5 g  I; ^+ W- P
    0.391  秒
    ' C3 j/ ~7 f$ \; g! `
    / W; b4 ~$ M+ u: ?$ h% R% t二者效率相差数十倍。
    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 21:13 , Processed in 0.445652 second(s), 68 queries .

    回顶部