zoukankan      html  css  js  c++  java
  • 函数的递归调用(专题)

    函数的递归调用(专题)

    递归调用:函数的递归调用,就是函数在执行的时候自动调用自己!

    功能:当我们把一个大问题按照某种解决方案细化为若干个小问题的时候,结果我们发现这些小问题的解决方案又和前面大问题的解决方案是一样的!

    语法格式:  function 函数名(){

                                         //递归出口(不要忘了,不然进入死循环)

    //调用其他函数;

    函数名();

    }

    函数名();

    所以,函数的递归有两个要素:

    1,  递归出口:就是什么时候停止自己调用自己

    2,  递归点:就是什么时候开始自己调用自己

    案例:斐波那契数列,即前两项已知,从第三项开始,每一项都是前两项的和!

      若前两项为1,则思路如下

                                1        (n<=2)       (出口)

             F(n)

                                F(n-1)+F(n-2)  (n>=2)   (递归点)

             function f($n){

                                //递归出口

                                If($n == 1||$n == 2){

                                return 1;

                                }

                                //递归点(由于就剩下一种结果了,我们可以直接使用即可)

                         $s=f($n-1)+f($n-2);

                         return $s

            }

        echo f($_GET[‘n’]);

    回味一下过程:

    特点:简单,但消耗内存,会占用大量的内在空间,当然运行较大的数会造成速度很慢

    优化过程,就是一个步骤的重复执行,降低空间,引用我们的迭代思想

    迭代思想:从前往后来解决问题,体现在代码上,其实就是一个步骤的重复的执行,也就是循环结构!

    做算法的过程中,我们首先要把思想逻辑写一下

    这样可以直接写代码了,甚至一气呵成

             <?php

             Function f($first,$second,$n){

                       //已知前两项

                       $before1 = $second;

                       $before2 = $first;

                       //条件判断前两项

                       if($n == 1){

                                return $first;

          }

          if($n == 2){

                                return $second;

          }

          for($i=3;$i<$n;$i++){

                 $num = $before1 + $before2;

                 $ before2=$before1;

              $before1=$num;

          }

          Return $num

        }

               Echo f(1,1,$_GET[‘n’]);

    算法思想并不是一朝一夕的,多加练习并总结,才是王道。

  • 相关阅读:
    Windows上使用“LogView”打开大文件
    windows CMD命令查看局域网内所有主机名及IP
    解决Sqlserver 2008 R2在创建登录名出错"此版本的 Microsoft Windows 不支持 MUST_CHANGE 选项。 (Microsoft SQL Server,错误: 15195)"
    解决 ASP.NET 编辑错误"CS0006: 未能找到元数据文件C:WINDOWSassemblyGAC_32System.EnterpriseServices2.0.0.0__b03f5f7f11d50a3aSystem.EnterpriseServices.dll"
    ASP 未结束的字符串常量
    Godaddy ssl续费更新问题总结
    [转]How to query posts filtered by custom field values
    SqlServer 在查询结果中如何过滤掉重复数据
    [UE4]C++的const类成员函数
    [UE4]C++三种继承方式
  • 原文地址:https://www.cnblogs.com/-010101/p/6085103.html
Copyright © 2011-2022 走看看