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



Algorithm Gossip: 费式数列

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

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


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

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("请输入迭代次数:\n");
	scanf("%d",&n);
	for(i = 0; i< n ; i ++)
	{
		c = a+ b;
		a = b;
		b = c;
	}
	printf("%d月后的兔子总数目为:%d\n",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",n,c);		    
			
		}
}


  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值