QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 9747|回复: 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递归程序为例进行比较。! L0 y& @3 Q& r- Z3 x  y; R! }; X

    ) A  i; w% d) SMatlab 2009a的Fibonacci函数定义:
    1. function k=fib(n)
      8 R  \: l# r) N6 L$ k
    2. if n == 0/ v* F2 O% k! F4 k9 P9 Q
    3.   k=0;
      7 J* \' q% J! z2 E
    4.   return;
      ! o4 m2 q8 S, p1 }, p
    5. else if n == 1
      # W9 i* o) n  b) w2 C: G3 C
    6.   k=1;
      9 t. g$ a, T$ ~2 B, V8 ?( q$ ~
    7.   return;3 B4 ^, H9 K. |/ s9 Z& T
    8. else* [6 I\" }9 _6 A- `\" Q
    9.   k=fib(n - 1) + fib(n - 2);) `, }& d0 h% P. d' P
    10.   return;\" Q$ T) J( x0 d0 g# i
    11. end  W. v' d/ d. X/ \% K8 ]* o  d
    12. end
    复制代码
    运行结果:
    1. tic;) C7 `6 d' e) `5 ]5 Z& w\" ~+ C4 D
    2. fib(30)7 D. |! y, d, ~4 r7 e' |0 _
    3. toc! ?5 h4 h7 Z$ N- d+ j) W
    4. : e' b& e/ f3 p* P- ?
    5. ans =9 L: Y6 [! Z\" e- k  E
    6.       832040
      5 w' |9 f& g( |

    7. , n3 B( G, G3 v1 G0 H( \
    8. Elapsed time is 26.315245 seconds.
    复制代码
    ===============9 Q& j4 ?, Y3 D9 L# W; x7 ~

      i0 u" k7 g: h) T# KForcal 9(OpenFC演示)的Fibonacci函数及代码:
    1. SetRealStackMax(1000);
      & r\" b5 W6 w\" J6 Z  U% ^3 g  m
    2. F(n)= which{
      - m8 }\" A( q, g, Q6 K$ ~  W
    3.     n == 0,% I: i, D4 m7 p
    4.         return(0),3 a1 L: F( v- G\" M: s; d: l\" q
    5.     n == 1,
      $ M8 Y0 {# s1 e9 M
    6.         return(1),
        E. A2 {+ J0 O* u) V\" A# u
    7.     return [F(n - 1) + F(n - 2)]
      ' Q\" K8 ?: ?: I) }6 I; Z$ \
    8. };; W2 j4 ~8 c# q; T! j& _
    9. mvar:
      * ?% x. T  b- V- Y& |6 K: D
    10. t=sys::clock(),
      ) d. g5 T3 n/ Y& t- f6 c
    11. F(30);; f+ v  i& D/ I/ a7 B
    12. [sys::clock()-t]/1000;
    复制代码
    结果:! T: n2 S) A5 n( r; G
    832040.: q: k7 \3 {2 b6 {; a4 [9 O" Z
    0.391  秒
    : r2 I7 I5 i' I+ o
    . q6 U4 o; V' K2 v6 A二者效率相差数十倍。
    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-13 08:05 , Processed in 0.454115 second(s), 68 queries .

    回顶部