斐波那契数列的应用

来源:互联网 发布:淘宝赚取佣金 编辑:程序博客网 时间: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]。

根据题意得:

  1. a[n]=a[n-1]+b[n-1]
  2. 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

 

 微笑

原创粉丝点击