学习递归笔记

一、概念

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

二、应满足的条件

(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();
        }

 

 

 

posted @ 2015-04-14 19:45  九省巡按  阅读(226)  评论(0编辑  收藏  举报