斐波那契数列的应用
来源:互联网 发布:淘宝赚取佣金 编辑:程序博客网 时间:2024/05/01 16:57
本文出自:http://blog.csdn.net/hongchangfirst
前几天看了一个面试题,现在把题目和思路整理如下,以飨读者。
对一个正整数作如下操作:如果是偶数则除以2,如果是奇数则加1,如此进行直到1时操作停止,求经过9次操作变为1的数有多少个?
我们可以先进行反向推理:
第9次操作:结果1只能由2产生。
第8次操作:结果2只能由4产生。
第7次操作:结果4由8、3产生。
第6次操作:结果8由16、7产生;结果3由6产生。
第5次操作:结果16由32、15产生;结果7由14产生;结果6由12、5产生。
我们从中可以看出,一个偶数必然由一个偶数或者是一个奇数产生(除2外,因为1是最终结果,不可能出现1+1=2得到2这种情况);一个奇数必然由一个偶数产生。也就是说,一个偶数可以产生一个偶数和一个奇数,一个奇数可以产生一个偶数。
根据每次操作所能产生的数的数量为1, 1, 2, 3, 5, 8, 13, 21, 34. . . . . . 我们可以猜测其数量为斐波那契数列。下面证明其数量是第几操作的斐波那契数列。
证法如下:
设a[n]为第n次计算时偶数的数量,b[n]为第n次计算时奇数的数量,sum[n]是第n次计算时的总数量,显然,sum[n]=a[n]+b[n]。
根据题意得:
- a[n]=a[n-1]+b[n-1]
- b[n]=a[n-1]
则总的个数等于偶数的个数加上奇数的个数:sum[n]=a[n]+b[n]
=a[n-1]+b[n-1]+a[n-1]
=a[n-1]+b[n-1]+a[n-2]+b[n-2]
=sum[n-1]+sum[n-2]
即证,sum为斐波拉契数列。
由于a[0]=1,b[0]=0
(只有数字2),
a[1]=1,b[1]=0
(只有数字4),
所以sum[0]=1,sum[1]=1。
由这两个初始值可以算出(经过一次操作的是sum[0]),所以经过9次操作的数为sum[8]=34。
- 斐波那契数列的应用
- 斐波那契数列的小应用
- 【水题算法】斐波那契数列的应用
- HDU5620——斐波那契数列的应用
- 斐波那契数列的应用(算法实现)
- 关于斐波那契数列的性质及其应用
- HDU5620 斐波那契数列的应用 思维 规律
- 常见斐波那契数列的性质及其应用
- P1349 广义斐波那契数列(矩阵的应用)
- 算法应用-斐波那契数列
- 斐波那契数列及其应用
- 斐波那契数列的非递归c语言实现以及斐波那契数列的应用
- 使用canvas 绘制斐波那契螺旋线(斐波那契数列的应用)
- [ACM]斐波那契数列对应的奇偶数列
- 斐波那契数列数列的实现
- 有趣的斐波那契数列
- 斐波那契数列的解法?
- 斐波那契数列的打印
- struts1.x的工作流程
- 1111
- 在Emacs下用C/C++编程
- 国外15个免费网页模板下载的集合网站
- magento输出到phtml
- 斐波那契数列的应用
- .net发布后访问水晶报表加载失败
- 好吧……我的博客开张了……
- java的System.getProperty()方法可以获取的值
- 乔布斯:初心与终点
- C++的指针问题。
- recvfrom
- mod_bandwidth 中文安装和设置说明.
- JAVA静态成员和静态内部类(一)