QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 9655|回复: 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递归程序为例进行比较。
    : o' {5 A' l' J8 U% k2 X2 j
    " q, t% R. e8 _! \Matlab 2009a的Fibonacci函数定义:
    1. function k=fib(n)0 r; c% U8 H; |
    2. if n == 0
      & W$ p& E! }! ^: k7 ]+ u
    3.   k=0;* y8 X/ y) V) z5 `* H$ f7 p& D
    4.   return;
      5 P( E! c8 z1 x5 B' j7 Y
    5. else if n == 1
      ( U: z0 w1 \) E, G
    6.   k=1;
      9 c* d6 }. {$ {/ F2 o* Q/ Y5 o
    7.   return;
      / q8 O% p! E8 r7 I% ]/ U
    8. else/ L: q9 _5 t3 b( i
    9.   k=fib(n - 1) + fib(n - 2);$ ]$ c\" }6 K+ O$ a3 q1 \
    10.   return;
      3 U8 `+ v8 Y# o6 o* [3 W+ y
    11. end$ r! R( g$ T$ X& ?
    12. end
    复制代码
    运行结果:
    1. tic;8 k, M( F+ c; S
    2. fib(30)+ v6 E' c; f4 _+ q3 k' c( g5 [
    3. toc$ h6 R$ \! g; n

    4. ! ?! }2 O# V+ p$ v
    5. ans =
      , h\" Y0 W% G, d: N1 D) v
    6.       8320408 f; {# a, W2 Z

    7. 6 W- Q. \/ q. u
    8. Elapsed time is 26.315245 seconds.
    复制代码
    ===============
    . x+ H! V$ Y8 Z- A
    ( I$ C3 x8 O' P# d# n* xForcal 9(OpenFC演示)的Fibonacci函数及代码:
    1. SetRealStackMax(1000);\" O) N5 r1 [\" Y  J/ K! I
    2. F(n)= which{
        O9 B3 X! H! v: a
    3.     n == 0,
      ' X3 B9 i) P5 K, I! }( W5 V8 {
    4.         return(0),
      1 l+ z! C' {( [, J8 D6 I; H
    5.     n == 1,& h: w  d: Z# `. {' ?3 u+ D
    6.         return(1),
      \" o, Z( u9 r4 O+ U- t  o3 ~\" ~& h
    7.     return [F(n - 1) + F(n - 2)]
      ( ?+ G  D. E% D# y5 V8 S6 \
    8. };
      / t8 d: y$ l5 {& w- b, O! C. |
    9. mvar:* a. R/ y8 T! ~2 ]  Q: w
    10. t=sys::clock(),! U5 ^; `: h( d2 z  A5 D
    11. F(30);
      * z3 ^+ Q: d% ~/ N/ z$ R9 g
    12. [sys::clock()-t]/1000;
    复制代码
    结果:% G- z& C) j$ T6 D
    832040.
    ) d+ r; e2 g4 z# _, V2 M# a1 F- v0.391  秒3 A; E0 G; \- O0 {* e/ Z  b5 K

      E  n5 B( x/ T/ ?' a1 \二者效率相差数十倍。
    zan
    转播转播0 分享淘帖0 分享分享0 收藏收藏0 支持支持0 反对反对0 微信微信
    alair005        
    头像被屏蔽

    0

    主题

    4

    听众

    782

    积分

    升级  45.5%

  • TA的每日心情

    2012-2-7 08:08
  • 签到天数: 5 天

    [LV.2]偶尔看看I

    提示: 作者被禁止或删除 内容自动屏蔽
    回复

    使用道具 举报

    0

    主题

    0

    听众

    3

    积分

    升级  60%

    该用户从未签到

    回复

    使用道具 举报

    您需要登录后才可以回帖 登录 | 注册地址

    qq
    收缩
    • 电话咨询

    • 04714969085
    fastpost

    关于我们| 联系我们| 诚征英才| 对外合作| 产品服务| QQ

    手机版|Archiver| |繁體中文 手机客户端  

    蒙公网安备 15010502000194号

    Powered by Discuz! X2.5   © 2001-2013 数学建模网-数学中国 ( 蒙ICP备14002410号-3 蒙BBS备-0002号 )     论坛法律顾问:王兆丰

    GMT+8, 2026-4-15 08:02 , Processed in 0.380631 second(s), 69 queries .

    回顶部