斐波那契数列

斐波那契数列译为黄金分割数列。最经典的问题就是兔子问题

  • 第一个月初有一对刚诞生的兔子
  • 第二个月之后(第三个月初)它们可以生育
  • 每月每对可生育的兔子会诞生下一对新兔子
  • 兔子永不死去

假设在n月有兔子总共a对n+1月总共有b对在n+2月必定总共有a+b对。

1,1,2,3,5,8,13,21,……


开普勒 发现数列前、后两项之比1/2 ,2/3 , 3/5 ,5/8 ,8/13 ,13/21 ,21/34 ,...... ,也组成了一个数列,会趋近 黄金分割
一、分析问题:问题到最后化简就是前两个数相加得到第三个数
二、画图分析:

可以使用ABC三个变量无限循环即可。但是循环要在第三次开始,所以前两次循环要使用判断语句跳过。
三、程序流程图:

四、程序实现源码:
#include<iostream>

using namespace std;

int main()
{
	
	unsigned int A = 0;
	unsigned int B = 1;
	unsigned int C = 1;

	unsigned int n;
	cout << "Enter count of Fibonacci:" << endl;
	cin >> n;

	if (n ==1 || n ==2)
	{
		C = 1;
	}
	else
	{
		for (int i = 3; i <= n; i++)
		{
			A = B;
			B = C;
			C = A + B;
		}
	}
	cout << C << endl;

	return 0;
}

python版本的:
n = int(input("Enter the count of Fibonacci:"))
A = 0
B = 1
C = 1

if (n == 1 or n == 2):
    pass
else:
    for i in range(3,n+1):
        A = B
        B = C
        C = A + B

print("%d"%C)




拓展(递归实现)
细心的人可能会发现流程图和程序有些是可以还能被优化的。其实整个算法用递归方法才最容易解决。(不想用递归就别别看了,不是有那么有句话吗?“菜鸟用循环,大神用递归”)

首先要知道,要写成递归,这个函数返回值是什么,毫无疑问肯定是C!因为C是你要输出的结果。但是C有等于什么?A + B,而通过上面的图可知道A和B都是曾经的C,所以程序就比较好写了。当然不要忘记形参是要求的第n个数。

程序源代码:
#include<iostream>

using namespace std;

int C_V(int n)//递归方法求C(这里的C_V是求C值是函数)
{
	if (n == 1 || n == 2)
	{
		return 1;
	}
	else
	{
		return C_V(n - 1) + C_V(n - 2);
	}
}

int main()
{
	int n;
	int C;
	cout << "Enter the count of Fibonacci:" << endl;
	cin >> n;
	
	C = C_V(n);
	cout << C << endl;

	return 0;
}

python版本的:
def C_V(n):
    if (n == 1 or n == 2):
        return 1
    else:
        return C_V(n-1)+C_V(n-2)

n =int(input("Enter count of Fibonacci:"))
C = C_V(n)
print("%d"%C)

注意:这里注重了原理实现,并没有对输入是否合法进行判断,这个逻辑可以自己加!




  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值