• 费事数列——我的理解


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

    View Code
        public class MainClass    
    {
    public static void Main()
    {
    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);
    }
    }

    第一个月有一对刚诞生的兔子  第两个月之后它们可以生育  每月每对可生育的兔子会诞生下一对新兔子  兔子永不死去  假设在n月有新生及可生 育的兔子总共a对,n+1月就总共有b对。在n+2月必定总共有a+b对:因为在n+2月的时候,所有在n月就已存在的a对兔子皆已可以生育并诞下a对后 代;同时在前一月(n+1月)之b对兔子中,在当月属于新诞生的兔子尚不能生育。  斐波那契数列又因数学家列昂纳多·斐波那契以兔子繁殖为例子而引入, 故又称为“兔子数列”。 

    我在纸上画了半天也没能理解,于是我就把兔子换成了人。

    (数列中的第一个1为张先生,第二个1为张先生娶了李小姐,2为他们结婚了,3为第一年)

    第一年 :张+李=赵(张先生和李小姐生了个儿子叫赵,于是乎一共就有了3口人)

    第二年:张+李=钱,赵+朱(张先生和李小姐生了个儿子叫钱,他们第一年生的儿子娶了个老婆叫朱,一共5口人)

    第三年:张+李=孙,赵+朱=鲁,钱+乐(张先生和李小姐生了个儿子叫孙,赵先生和朱小姐生了个儿子叫鲁,钱先生娶了个老婆叫乐一共8口人)

    第四年:张+李=周,赵+朱=韦,钱+乐=计,孙+梅,鲁+丁(张先生和李小姐生了个儿子叫周,赵先生和朱小姐生了个儿子叫韦,钱先生和乐小姐生了个儿子叫计,孙前生娶了个老婆叫梅,鲁先生娶了个老婆叫丁,一共13口人)

    第五年:张+李=吴,赵+朱=昌,钱+乐=于,孙+梅=芮,鲁+丁=宁,周+叶,韦+闻,计+温(张先生和李小姐生了个儿子叫吴,赵先生和朱小姐生 了个儿子叫昌,钱先生和乐小姐生了个儿子叫于,孙先生和梅小姐生了个儿子叫芮,鲁先生和丁小姐生了个儿子叫宁,周先生娶了个老婆叫叶,韦先生娶了个老婆 闻,计先生娶了个老婆叫温,一共21口人)

    ......

    这样理解我就能理解上面的算法实现了

  • 相关阅读:
    Pixar 故事公式
    你想住在中国哪里
    tar.gz方式安装nacos设置使用systemct进行service方式的管理并设置开机自启动
    记一个nginx server_name配置多个时的坑
    linux软链接的创建、修改和删除
    阿里云SLB的健康检查配置
    (转载)bullet安装之——windows下的安装与VS开发
    [译] 找到ndarray中的重复行
    [译] 对dataframe数据按照某列值进行分组,分组后连接字符串
    [译] 如何将列表嵌套列表的情况转化成一维列表
  • 原文地址:https://www.cnblogs.com/tony312ws/p/2127206.html
Copyright © 2020-2023  润新知