牛数问题解析

一个农夫养了一头牛,三年后,这头牛每年会生出1头牛,生出来的牛三年后,又可以每年生出一头牛……问农夫10年后有多少头牛?n年呢?

这里主要谈一下解决这种问题的思想。首先可以联系斐波那契数列,设f(n)为第n年的牛,则

f(n) = f(n - 1) + f(n - 2)————>表达式1-1

即第n年的牛为去年牛的个数f(n - 1)加上今年出生牛的个数,那么今年有多少头牛能生呢?(不考虑死亡的牛)则为前年牛的个数即f(n - 2),因为前年的牛今年至少3岁,即为表达式1-1

 

 

推广一下,将牛生育年龄设为m,那么计算的表达式就变为

f(n) = f(n - 1) + f(n - m + 1)————>表达式1-2

n-1年牛的个数加上n-m+1年的牛生出的小牛。

 

那么下面讨论一个稍微复杂点的问题,如果增加一个条件,即牛会在第8年死去,那么第n年会有多少条牛呢?

为了便于推导,这里先设几个函数:

·         f(n)即第n年牛的个数

·         h(n)即第n年出生的牛的个数

·         g(n)即第n年死亡的牛的个数

那么这里可以首先想到一个表达式:

(1)f(n) = f(n -1) + h(n) - g(n)

即第n年牛的个数为第n-1年牛的个数+n年出生的牛的个数-n年死亡的牛的个数

而第二个表达式即关于新增牛的个数h(n)的:

(2)h(n) = f(n - 2) - g(n - 1)

即第n年出生的牛的个数为第n-2年牛的个数减去在第n-1年死亡的牛的个数

再看第三个表达式关于第n年死亡的牛的个数的:

(3)g(n)=h(n - 7)

即第n年死亡的牛的个数为第n - 7年出生的牛的个数,这是一个对称的关系。

 

推导的步骤如下,将(2)代入(1)

f(n) = f(n - 1) + f(n - 2)- g(n - 1) - g(n)---->4

再将(3)式代入(4)

f(n) = f(n - 1) + f(n - 2) - h(n - 8) - h(n - 7)----->(5)

再将(2)式代入(5)的h(n - 7)

f(n) = f(n - 1) + f(n - 2) - (h(n - 8) - f(n - 9) + g(n - 8))

到了这里不难看出(h(n - 8) + f(n - 9) - g(n - 8))即为f(n - 8)通过式(1)

则最终的表达式为

f(n) = f(n - 1) + f(n - 2) - f(n - 8)

即第n年牛的个数为第n-1年牛的个数+n-2年牛的个数-n-8年牛的个数

当牛的生育年龄用a表示,死亡年龄用b表示时,则表示为:

f(n) = f(n - 1) + f(n  a + 1) - f(n - b)

 

源码如下:

//f(n)=f(n-1)+f(n-a+1)-f(n-b)

 

int a=3;

int b=8;

int cowCount(int n)

{

    if(n<=0) return 1;

    else if(n==1) return 2;

    else return cowCount(n-1)+cowCount(n-a+1)-cowCount(n-b);

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值