zoukankan      html  css  js  c++  java
  • 费事数列——我的理解

     一列数的规则如下: 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口人)

    ......

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

  • 相关阅读:
    webpack2 前篇
    vue 的调试工具
    CSS 命名规范总结
    reset.css
    推荐几个精致的web UI框架
    自己是个菜鸟 自己查找的简单的适合初学的Makefile
    Linux下编译、使用静态库和动态库 自己测过的
    函数参数的传递 动态内存传递问题(指针的指针)
    二级指针 (C语言)
    find_if查找vector内对象的成员 作为菜鸟一直不会用也不敢用
  • 原文地址:https://www.cnblogs.com/tony312ws/p/2127206.html
Copyright © 2011-2022 走看看