算法之斐波那契数列(Fabonacci)

 

说明:Fibonacci为1200年代的欧洲数学家,在他的着作中曾经提到:「若有一只免子每个月生一只小免子,一个月后小免子也开始生产。起初只有一只免子,一个月后就有两只免子,二个月后有三只免子,三个月后有五只免子(小免子投入生产)......。

如果不太理解这个例子的话,举个图就知道了,注意新生的小免子需一个月成长期才会投入生产,类似的道理也可以用于植物的生长,这就是Fibonacci数列,一般习惯称之为费氏数列,例如以下: 1、1、2、3、5、8、13、21、34、55、89......

解法:依说明,我们可以将费氏数列定义为以下:

fn = fn-1 + fn-2   if n > 1

fn = n       if n= 0, 1

C 语言版本:

#include "stdio.h"
#include "conio.h"
int main()
{
	int a,b,c;
	int i;
	int n;
	a = 1;
	b = 1;
	c = a + b;
	printf("请输入迭代次数:
");
	scanf("%d",&n);
	for(i = 0; i< n ; i ++)
	{
		c = a+ b;
		a = b;
		b = c;
	}
	printf("%d月后的兔子总数目为:%d
",n,c);
	getch();
		return 0;
}

Java版本:

import java.util.Scanner;
public class Fabonacci {
		public static void main(String[] args)
		{
			int a,b,c;
			a = 1;
			b = 1;
			c = a + b;
			int n;
		    Scanner input = new Scanner(System.in);
		    System.out.println("请输入迭代月数:");
		    n = input.nextInt();
		    for(int i = 0; i < n; i ++)
		    {
		    	c = a + b;
		    	a = b;
		    	b = c;
		    }
		    System.out.printf("%d月之后的兔子总量为:%d
",n,c);		    
			
		}
}


经验分享 程序员 微信小程序 职场和发展