`
xufei0110
  • 浏览: 110628 次
  • 性别: Icon_minigender_1
  • 来自: 大连
社区版块
存档分类
最新评论

斐波那契数列 农夫养牛问题

 
阅读更多

记下来自己看的。

问题: (CSDN上看到的)

      一个农夫养了一头牛,三年,这头牛每年会生出1头牛,生出来的牛三年后,又可以每年生出一头牛……问农夫10年后有多少头牛?n年呢?

 

     这个问题的数学模型是: 斐波那契数列(兔子序列)。

 

     斐波那契数列指的是这样一个数列:1、1、2、3、5、8、13、21、……

   这个数列从第三项开始,每一项都等于前两项之和。它的通向公式:(1/√5)*{[(1+√5)/2]^n - [(1-√5)/2]^n}(又叫“比内公式”,是用无理数表示有理数的一个范例。)(√5表示根号5)

 

这个是数学公式的:

     

 

 

public class Fibonacci   
{   
  public static void main(String[] args)   
  {   
      int x=1,y=1;   
      System.out.println(x+" ");   
      for(int i=1; i<=10; i++)   
      {   
          System.out.println(y+" ");   
          y=x+y;   
                  x=y-x;   
      }   
  }   
}

 看起来很简单 根据公式来。

 

 这个是递归的:

 

private int Fibonacci(num)
{
  if(num <= 2){
      return 1;
  }else{
      return Fibonacci(num - 1) + Fibonacci(num - 2) 
  }
}

public static void main(String[] args)
{
      Fibonacci(10);
}

 

也是根据公式来的。

 

 

这个是面向对象的:

class Cow 
{ 
    private int age; 
    
    public Cow() 
    { 
        age = 0; 
    } 
    
    public Cow bearCow()//生小牛 
   { 
        return new Cow(); 
    } 
    
    public void grow()//每年牛龄加1 
    { 
        age = age + 1; 
    } 
    
    public int getAge() 
    { 
        return age; 
    } 
} 
public class Main { 
    private static Set <Cow> cowSet = new HashSet <Cow>();//牛圈,存放所有的牛 

    public static int check()//每年检测一边所有的牛,年龄要加一,并且够岁数了要生效牛 
    { 
           Set <Cow> newCowSet = new HashSet <Cow>(); 
           for(Cow cow : cowSet) 
          { 
               cow.grow();//年龄加一 
          if(cow.getAge() >= 3) 
                  newCowSet.add(cow.bearCow());//够岁数的生小牛 
            
       } 
           cowSet.addAll(newCowSet);//把所有生出来的小牛放牛圈里 
        return cowSet.size(); 
    } 
    public static void main(String args[]) 
    { 
        Cow cow = new Cow(); 
        cowSet.add(cow); 
        for(int i = 0; i < 10; i ++) 
        { 
            System.out.println(i+1 + " : " + check()); 
        } 
    } 

}

 看起来有点傻。不过现实中遇到的可能都会这么写。不是我写的 呵呵。

 

 

 相关的一个问题:

 

   有一段楼梯有10级台阶,规定每一步只能跨一级或两级,要登上第10级台阶有几种不同的走法?

  这就是一个斐波那契数列:登上第一级台阶有一种登法;登上两级台阶,有两种登法;登上三级台阶,有三种登法;登上四级台阶,有五种登法……

  1,2,3,5,8,13……所以,登上十级,有89种走法。有一段楼梯有10级台阶,规定每一步只能跨一级或两级,要登上第10级台阶有几种不同的走法?

  这就是一个斐波那契数列:登上第一级台阶有一种登法;登上两级台阶,有两种登法;登上三级台阶,有三种登法;登上四级台阶,有五种登法……

  1,2,3,5,8,13……所以,登上十级,有89种走法。

 

 

代码是抄来的没有测试过。

分享到:
评论

相关推荐

    Fibonacci数列斐波那契数列PPT学习教案.pptx

    "Fibonacci数列斐波那契数列PPT学习教案.pptx" Fibonacci数列是一种非常重要的数学概念,它的应用非常广泛,包括生物学、经济学、计算机科学等领域。下面我们将详细介绍Fibonacci数列的概念、性质和应用。 1. ...

    Labview实现递归:斐波那契数列

    斐波那契数列: 在数学上它以递归的方式进行定义,指这样的一个数列:0、1、1、2、3、5、8、13、21、34、55、89、144……,即前两个数为分别为0和1,从第3项开始,每项的值都等于其前两项之和。斐波那契数列Fib(n)用...

    (新课标)2020年高考数学 题型全归纳 斐波那契数列.doc

    同样,走楼梯问题也可以用斐波那契数列解决,每步可以走一级或两级,计算走n级楼梯的不同方式数,与斐波那契数列的计算方式相似。 此外,斐波那契数列还与黄金矩形、黄金螺旋、黄金角等几何形状紧密关联。这些形状...

    斐波那契数列(前100项).rar

    5. **问题解决**:在编程竞赛和面试中,斐波那契数列经常被用来作为问题背景,考察候选人的算法设计和优化能力。 6. **数据结构**:斐波那契堆是一种高效的数据结构,用于优先队列操作,其名字来源于斐波那契数列。...

    编写函数f,功能是用递归的方法求斐波那契数列的第n项

    【问题描述】编写函数f,功能是用递归的方法求斐波那契数列的第n项,函数原型为 int f(int n),在主函数中输入一个正整数n,调用函数f求出斐波那契数列的第n项,并在主函数中输出。 斐波那契数列:1,1,2,3,5,8,13,...

    java实现Fibonacci数列

    根据给定文件的信息,我们可以详细地探讨如何使用Java来实现Fibonacci数列,并通过具体的代码示例来深入了解这一主题。 ### Java实现Fibonacci数列 #### 1. Fibonacci数列简介 Fibonacci数列是一系列数字,其中每...

    C语言解答经典的数学问题兔子繁衍问题即斐波那契数列问题

    这个经典的数学问题不仅展示了斐波那契数列的基本应用,同时也体现了编程解决问题的逻辑思维。通过迭代或递归方式实现斐波那契数列的计算是计算机科学教育中常见的练习,有助于学生理解和掌握算法以及控制流程的概念...

    斐波那契数列.pdf

    - **动态规划**:斐波那契数列问题常作为动态规划的入门案例,通过存储已计算的结果来避免重复计算,提高效率。 - **算法优化**:在解决某些算法问题时,利用斐波那契数列的性质可以优化解决方案。 ##### 2. 艺术与...

    利用Matlab程序计算斐波那契数列的前一百项

    在这个MATLAB程序中,我们首先定义了斐波那契数列的前两项`fibonacci = [1, 2]`,然后通过`for`循环从第三项开始计算,直到第一百项。在每次循环中,我们使用`fibonacci(k)`存储当前项,它是前两项`fibonacci(k-1)`...

    斐波那契数列毕业设计论文斐波那契数列的应用本科论文.doc

    斐波那契数列毕业设计论文斐波那契数列的应用本科论文.doc 斐波那契数列是数学中一个非常重要的概念,它自问世以来不断显示出它在数学理论和应用上的重要作用。该数列在现代物理、准晶体结构、生物、交通、化学等...

    求解fibonacci数列的前20项

    ### Fibonacci数列的基础概念 Fibonacci数列是数学中一个经典的数列,以其独特的性质在计算机科学、数学分析等领域有着广泛的应用。该数列由0和1开始,之后每一项都是前两项的和。即:0, 1, 1, 2, 3, 5, 8, 13, 21,...

    Python实现斐波那契数列

    程序分析:斐波那契数列(Fibonacci sequence),又称黄金分割数列,指的是这样一个数列:0、1、1、2、3、5、8、13、21、34、…… 在数学上,费波那契数列是以递归的方法来定义: F0 = 0 (n=0) F1 = 1 (n=1) Fn ...

    一个标注斐波那契数列的指标--K线数量 主图指标通达信指标.doc

    斐波那契数列指标在技术分析中的应用 本文档介绍了一个基于斐波那契数列的指标,用于股票市场的技术分析。该指标结合了指数移动平均线(EMA)和斐波那契数列,旨在帮助投资者更好地分析和预测股票市场的走势。 ...

    斐波那契数列-C++代码

    本代码使用C++语言书写,编译环境VS2013。...斐波那契数列(Fibonacci Sequence)又称黄金分割数列,指的是这样一个数列:0、1、1、2、3、5、8、13、21、…… 本代码是练习作品,如有错误或修改,请指正,感谢感谢。

    非递归实现fibonacci数列

    使用C++非递归实现fibonacci数列,对正在学习算法的同学应该挺有帮助的

    斐波那契数列及其性质

    例如,覆盖问题,如使用不同尺寸的骨牌覆盖棋盘,可以转化为斐波那契数列的问题,通过递推关系求解覆盖方法的数量。爬楼梯问题,一个人爬楼梯可以选择一步一阶或一步两阶,求解不同爬楼方式的数量同样可以用斐波那契...

    Fibonacci(斐波那契)数列的JAVA解法

    递归算法是解决斐波那契数列问题的一种常见方法。该方法的思想是将问题分解成更小的子问题,直到问题的答案变得明确。下面是一个使用递归算法计算斐波那契数列的JAVA代码: public class Fib_ra{ public static int...

    Fibonacci数列(非递归的函数调用)

    斐波那契数列是一个经典的数学概念,在计算机科学中经常被用作算法示例和问题解决的工具。这个数列的定义是这样的:第一项F0等于0,第二项F1等于1,从第三项开始,每一项都等于前两项之和。即Fn = Fn-1 + Fn-2 (n &gt;=...

    算法-数论- 斐波那契数列(Fibonacci).rar

    这个数列由意大利数学家斐波那契(Leonardo Fibonacci)在13世纪引入,用于模拟兔子繁殖的问题,因此也被称为“兔子数列”。数列的定义非常简单:第一项是0,第二项是1,之后每一项都是前两项之和。用数学公式表示...

    MIPS汇编实验:斐波那契数列

    在这个"MIPS汇编实验:斐波那契数列"中,我们主要关注的是如何使用C语言和MIPS汇编来实现斐波那契数列的计算,并进行溢出和输入检测。斐波那契数列是由两个前一个数相加得到的数列,通常以0和1开始。 首先,我们看...

Global site tag (gtag.js) - Google Analytics