A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

© 伱涐的距离 中级黑马   /  2013-12-24 09:47  /  786 人查看  /  2 人回复  /   0 人收藏 转载请遵从CC协议 禁止商业使用本文

本帖最后由 伱涐的距离 于 2013-12-24 10:01 编辑

一列数的规则如下:1、1、2、3、5、8、13、21、34……求第30位数是多少?
怎样用递归算法实现呢?

评分

参与人数 1技术分 +1 收起 理由
茹化肖 + 1

查看全部评分

2 个回复

倒序浏览
class Program
    {
        static void Main(string[] args)
        {
            Console.WriteLine(Foo(30));

        }
        public static int Foo(int i)
        {
            if (i <= 0)
                return 0;
            else if (i > 0 && i <= 2)
                return 1;
            else return Foo(i - 1) + Foo(i - 2);

        }
    }

评分

参与人数 1技术分 +1 收起 理由
茹化肖 + 1

查看全部评分

回复 使用道具 举报
这个一定要递归实现啊,其实我觉得for循环获取更方便
回复 使用道具 举报
您需要登录后才可以回帖 登录 | 加入黑马