• 学习递归笔记


    一、概念

    函数体内调用本函数自身,直到符合某一条件不可继续调用。

    二、应满足的条件

    (1).有反复执行的过程(调用自身)。

    (2).有跳出反复执行过程的条件(函数出口)。

    三、注意事项

    1.递归中必须要存在一个循环结束的条件。

    2.递归函数的每次调用都需要栈来存储,如果次数太多的话容易造成栈溢出。

    例:每一天卖掉二分之一只又一只羊,经过7天后剩下2只羊,问最初几只羊

    public int ganyang(int day)                  //试着写了另一种方法 sum=ganyang(day-1)/2-1; 第几个村子的羊等于上一个村子的羊除以2减去1
            {                                    //一直没写成功,都是死循环。想到递归的调用顺序可能是,已知的初值如果在后面,那就由后往前推
                int sum = 0;                     //如果已知的初值在前面,就由前往后推
                if (day == 7)
                {
                    sum = 2;
                    return sum;
                }
                sum = (ganyang(day + 1) + 1) * 2;//当天的羊等于下一天的羊加1然后乘以2 假如输入参数day=6 当执行到这一步时,会继续调用函数ganyang(day+1) 这时day就变成7了,满足                                               if条件,sum=2,然后继续执行公式~~ 
                return sum;
            }
            static void Main(string[] args)
            {
                int sum = new Program().ganyang(0);
                Console.WriteLine(sum);
                Console.ReadLine();
            }
        }
    }



            /// <summary>
            /// 求总共多少对兔子。两只幼兔,一个月后长成成兔并生下一对幼兔,问多少个月后有多少对兔子
            /// </summary>
            /// <param name="m">多少个月数</param>
            /// <returns>兔子的总对数</returns>
            public int tuzi(int m)//输入参数m为第几个月
            {
                int s;
                if (m==0)            //第0个月,也就是刚开始是一对幼兔
                {
                    s = 1;
                    return s;//这边一定记得也加个return 不然m==0时的s值送不出去,下面的公式无法获得s的值
                }
                s = tuzi(m-1) * 2;//找规律,本月的兔子总和是(上月成兔+上月幼兔)*2, 本函数求的就是某月兔子的总对数,所以上月兔子的总对数就是tuzi(m-1)
                return s;//把计算结果输出函数
            }
    
    
            static void Main(string[] args)
            {
                int sum = new Program().tuzi(4);
                Console.WriteLine(sum);
                Console.ReadLine();
            }
    
    
    
     
  • 相关阅读:
    看了前辈缠中说禅及其反响,忍不住想说些东西
    利弗莫尔的操盘精华篇
    缠中说禅:教你炒股票108课(转载)
    评温斯坦的炒股书(非常重要,常看看)
    本散女2
    使用PHP-GTK编写一个windows桌面应用程序
    php.exe php-cgi.exe php-win.exe的区别
    php调试利器之phpdbg
    yaf框架安装配置
    phalcon框架安装
  • 原文地址:https://www.cnblogs.com/happinesshappy/p/4425873.html
Copyright © 2020-2023  润新知