记下来自己看的。
问题: (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数列是一种非常重要的数学概念,它的应用非常广泛,包括生物学、经济学、计算机科学等领域。下面我们将详细介绍Fibonacci数列的概念、性质和应用。 1. ...
斐波那契数列: 在数学上它以递归的方式进行定义,指这样的一个数列:0、1、1、2、3、5、8、13、21、34、55、89、144……,即前两个数为分别为0和1,从第3项开始,每项的值都等于其前两项之和。斐波那契数列Fib(n)用...
解决这一问题的C语言程序中,关键函数是`fibonacci`,它负责计算斐波那契数列的第n项。该函数接收一个整数n作为参数,代表所求的月份数。如果输入的n小于等于0,函数将返回0,因为这表示没有兔子开始繁衍。如果n为1...
同样,走楼梯问题也可以用斐波那契数列解决,每步可以走一级或两级,计算走n级楼梯的不同方式数,与斐波那契数列的计算方式相似。 此外,斐波那契数列还与黄金矩形、黄金螺旋、黄金角等几何形状紧密关联。这些形状...
5. **问题解决**:在编程竞赛和面试中,斐波那契数列经常被用来作为问题背景,考察候选人的算法设计和优化能力。 6. **数据结构**:斐波那契堆是一种高效的数据结构,用于优先队列操作,其名字来源于斐波那契数列。...
【问题描述】编写函数f,功能是用递归的方法求斐波那契数列的第n项,函数原型为 int f(int n),在主函数中输入一个正整数n,调用函数f求出斐波那契数列的第n项,并在主函数中输出。 斐波那契数列:1,1,2,3,5,8,13,...
根据给定文件的信息,我们可以详细地探讨如何使用Java来实现Fibonacci数列,并通过具体的代码示例来深入了解这一主题。 ### Java实现Fibonacci数列 #### 1. Fibonacci数列简介 Fibonacci数列是一系列数字,其中每...
- **动态规划**:斐波那契数列问题常作为动态规划的入门案例,通过存储已计算的结果来避免重复计算,提高效率。 - **算法优化**:在解决某些算法问题时,利用斐波那契数列的性质可以优化解决方案。 ##### 2. 艺术与...
在这个MATLAB程序中,我们首先定义了斐波那契数列的前两项`fibonacci = [1, 2]`,然后通过`for`循环从第三项开始计算,直到第一百项。在每次循环中,我们使用`fibonacci(k)`存储当前项,它是前两项`fibonacci(k-1)`...
斐波那契数列毕业设计论文斐波那契数列的应用本科论文.doc 斐波那契数列是数学中一个非常重要的概念,它自问世以来不断显示出它在数学理论和应用上的重要作用。该数列在现代物理、准晶体结构、生物、交通、化学等...
### Fibonacci数列的基础概念 Fibonacci数列是数学中一个经典的数列,以其独特的性质在计算机科学、数学分析等领域有着广泛的应用。该数列由0和1开始,之后每一项都是前两项的和。即:0, 1, 1, 2, 3, 5, 8, 13, 21,...
程序分析:斐波那契数列(Fibonacci sequence),又称黄金分割数列,指的是这样一个数列:0、1、1、2、3、5、8、13、21、34、…… 在数学上,费波那契数列是以递归的方法来定义: F0 = 0 (n=0) F1 = 1 (n=1) Fn ...
本代码使用C++语言书写,编译环境VS2013。...斐波那契数列(Fibonacci Sequence)又称黄金分割数列,指的是这样一个数列:0、1、1、2、3、5、8、13、21、…… 本代码是练习作品,如有错误或修改,请指正,感谢感谢。
使用C++非递归实现fibonacci数列,对正在学习算法的同学应该挺有帮助的
例如,覆盖问题,如使用不同尺寸的骨牌覆盖棋盘,可以转化为斐波那契数列的问题,通过递推关系求解覆盖方法的数量。爬楼梯问题,一个人爬楼梯可以选择一步一阶或一步两阶,求解不同爬楼方式的数量同样可以用斐波那契...
递归算法是解决斐波那契数列问题的一种常见方法。该方法的思想是将问题分解成更小的子问题,直到问题的答案变得明确。下面是一个使用递归算法计算斐波那契数列的JAVA代码: public class Fib_ra{ public static int...
斐波那契数列是一个经典的数学概念,在计算机科学中经常被用作算法示例和问题解决的工具。这个数列的定义是这样的:第一项F0等于0,第二项F1等于1,从第三项开始,每一项都等于前两项之和。即Fn = Fn-1 + Fn-2 (n >=...
在金融市场分析领域,斐波那契数列的应用一直是一个备受关注的话题。它不仅仅是一个简单的数字游戏,更是一种深刻反映市场内在规律的工具。在技术分析中,将斐波那契数列与主图指标结合,开发出一种新的分析方法,...
例如,在解决福建省泉州市模拟考试中的数学题目时,斐波那契数列可能被用来解决递归关系、数列求和或者寻找特定项的值等问题。通过这些实践应用,学生能够更好地理解和掌握数列的原理,并将其运用到实际问题的解决中...
这个数列由意大利数学家斐波那契(Leonardo Fibonacci)在13世纪引入,用于模拟兔子繁殖的问题,因此也被称为“兔子数列”。数列的定义非常简单:第一项是0,第二项是1,之后每一项都是前两项之和。用数学公式表示...