求Fibonacci数列通项公式
0. Intro
0 & (n=0) \\
1 & (n=1) \\
f_{n-1}+f_{n-2} & (n>1)
\end{cases}\]
这个就是众所周知的Fibonacci数列
用生成函数可以求出该数列的通项公式
1. 生成函数
生成函数分为普通型生成函数(OGF)和指数型生成函数(EGF),后面默认提到生成函数都是OGF
若有一数列 \(A: a_0,a_1,a_2,a_3,\cdots\) ,则 \(A\) 的生成函数为
\]
为了熟悉生成函数,先来看一个很基础的例子:
已知数列 \(f_n=1\) ,求 \(f\) 的生成函数 \(F(x)\) 。
直接代到定义式里就好了
\]
发现这里其实就是一个等比数列求和
\]
研究生成函数时我们都假设级数收敛
如果你不知道级数收敛是什么意思 只需要知道生成函数中的 \(x\) 没有实际意义 所以我们可以任意取值 所以不妨设 \(0<x<1\)
那么当 \(i\) 趋向于无穷大时,\(x^i\) 显然趋于 \(0\)
于是就得到了一个很简单的式子
\]
同理可以得到三个关于等比数列的生成函数的结论:
数列 \(1,q,q^2,q^3,\cdots\) (下标从0开始,下同)的生成函数是 \(F_1(x)=\dfrac1{1-qx}\)
数列 \(0,1,q,q^2,q^3,\cdots\) 的生成函数是 \(F_2(x)=\dfrac x{1-qx}\)
数列 \(q,q^2,q^3,q^4,\cdots\) 的生成函数是 \(F_3(x)=\dfrac q{1-qx}=-\dfrac1{x-\frac1q}\)
2. Fibonacci数列通项公式
1 & (n=0) \\
1 & (n=1) \\
f_{n-1}+f_{n-2} & (n>1)
\end{cases}\]
注意这里的 \(f_0=f_1=1\) ,和开头的那个不一样,因为这样设推起来更方便
设 \(f_n\) 的生成函数为 \(F(x)\) ,那么我们肯定首先要把 \(F(x)\) 求出来
x^2F(x) &=& & & & & f_0 x^2 & + & f_1 x^3 & + &\cdots & (1)\\
xF(x) &=& & & f_0 x & + & f_1 x^2 & + & f_2 x^3 & + &\cdots & (2)\\
F(x) &=& f_0 & + & f_1 x & + & f_2 x^2 & + & f_3 x^3 & + &\cdots & (3)\\
\end{matrix}\]
\((1)+(2)-(3)\) 得 \((x^2+x-1)F(x)=-1\)
所以 \(F(x)=\dfrac{1}{1-x-x^2}\)
然而我们并不能由此直接看出 \(f\) 的通项公式
数列 \(1,q,q^2,q^3,\cdots\) (下标从0开始,下同)的生成函数是 \(F_1(x)=\dfrac1{1-qx}\)
数列 \(0,1,q,q^2,q^3,\cdots\) 的生成函数是 \(F_2(x)=\dfrac x{1-qx}\)
数列 \(q,q^2,q^3,q^4,\cdots\) 的生成函数是 \(F_3(x)=\dfrac q{1-qx}=-\dfrac1{x-\frac1q}\)
要从生成函数反推出原数列 我们只知道这三个相关的结论
那么我们以这三个结论为目标试着做一些代数变形
\]
分母显然要降次
设方程 \(1-x-x^2=0\) 的两根为 \(x_1=\dfrac{-1+\sqrt5}2,x_2=\dfrac{-1-\sqrt5}2\) ,则 \(1-x-x^2=-(x-x_1)(x-x_2)\)
\]
而 \(\dfrac1{x-x_1}-\dfrac1{x-x_2}=\dfrac{(x-x_2)-(x-x_1)}{(x-x_1)(x-x_2)}=\dfrac{x_1-x_2}{(x-x_1)(x-x_2)}\)
所以 \(F(x)=-\dfrac1{x_1-x_2}\cdot\left(\dfrac1{x-x_1}-\dfrac1{x-x_2}\right)\)
其中含 \(x\) 的部分和 \(F_3(x)\) 很接近了
先把最前面的负号乘进去
\]
易知 \(x_1x_2=-1\) ,所以 \(x_2=-\dfrac1{x_1},x_1=-\dfrac1{x_2}\)
\]
由结论三可知,对于数列 \(a_n=(-x_1)^{n+1}\) ,它的生成函数是 \(G(x)=-\dfrac1{x-\frac1{-x_1}}\)
对于数列 \(b_n=(-x_2)^{n+1}\) ,它的生成函数是 \(H(x)=-\dfrac1{x-\frac1{-x_2}}\)
\]
这足以说明 \(f_n=\dfrac{b_n-a_n}{x_1-x_2}\) (请读者自行证明)
所以 \(f_n=\dfrac{(-x_2)^{n+1}-(-x_1)^{n+1}}{x_1-x_2}\)
将 \(x_1=\dfrac{-1+\sqrt5}2,x_2=\dfrac{-1-\sqrt5}2\) 代入
\]
这样就得到了通项公式
而如果是开头那个版本的斐波拉契数列:
0 & (n=0) \\
1 & (n=1) \\
f_{n-1}+f_{n-2} & (n>1)
\end{cases}\]
它的通项公式就是
\]
3. 总结
(与前面的内容可能有些出入)
数列 \(a_0,a_1,a_2,a_3,\cdots\) 的普通型生成函数(OGF)(以下称为生成函数)为
\]
首项为 \(a\) ,公比为 \(q\) 的等比数列(即 \(a,qa,q^2a,q^3a,\cdots\) )的生成函数为
\]
当 \(a=q\) 时可知数列 \(q,q^2,q^3,\cdots\) 的生成函数为
\]
这个结论可以用来推导斐波拉契数列的通项公式
斐波拉契数列的递推式:
0 & (n=0) \\
1 & (n=1) \\
f_{n-1}+f_{n-2} & (n>1)
\end{cases}\]
(也有 \(f_0=f_1=1\) 的版本,不唯一)
斐波拉契数列的生成函数(这里 \(f_0=f_1=1\) ):
\]
斐波拉契数列的通项公式(这里 \(f_0=0,f_1=1\) )
\]
求Fibonacci数列通项公式的更多相关文章
- 用PL0语言求Fibonacci数列前m个中偶数位的数
程序说明:求Fibonacci数列前m个中偶数位的数: 这是编译原理作业,本打算写 求Fibonacci数列前m个数:写了半天,不会写,就放弃了: 程序代码如下: var n1,n2,m,i; pro ...
- C++项目參考解答:求Fibonacci数列
[项目:求Fibonacci数列] Fibonacci数列在计算科学.经济学等领域中广泛使用,其特点是:第一.二个数是1,从第3个数開始,每一个数是其前两个数之和.据此,这个数列为:1 1 2 3 5 ...
- 程序员面试题精选100题(16)-O(logn)求Fibonacci数列[算法]
作者:何海涛 出处:http://zhedahht.blog.163.com/ 题目:定义Fibonacci数列如下: / 0 n=0 f(n)= ...
- 《面试题精选》15.O(logn)求Fibonacci数列
题目:定义Fibonacci数列例如以下: / 0 n=0 f(n)= 1 n=1 ...
- 用Python实现求Fibonacci数列的第n项
1. 背景——Fabonacci数列的介绍(摘自百度百科): 斐波那契数列(Fibonacci sequence),又称黄金分割数列.因数学家列昂纳多·斐波那契(Leonardoda Fibonacc ...
- POJ-3070Fibonacci(矩阵快速幂求Fibonacci数列) uva 10689 Yet another Number Sequence【矩阵快速幂】
典型的两道矩阵快速幂求斐波那契数列 POJ 那是 默认a=0,b=1 UVA 一般情况是 斐波那契f(n)=(n-1)次幂情况下的(ans.m[0][0] * b + ans.m[0][1] * a) ...
- 牛客IOI周赛17-提高组 卷积 生成函数 多项式求逆 数列通项公式
LINK:卷积 思考的时候 非常的片面 导致这道题没有推出来. 虽然想到了设生成函数 G(x)表示最后的答案的普通型生成函数 不过忘了化简 GG. 容易推出 \(G(x)=\frac{F(x)}{1- ...
- 16.O(logn)求Fibonacci数列[Fibonacci]
[题目] log(n)时间Fib(n),本质log(n)求a^n. [代码] C++ Code 12345678910111213141516171819202122232425262728293 ...
- POJ ---3070 (矩阵乘法求Fibonacci 数列)
Fibonacci Description In the Fibonacci integer sequence, F0 = 0, F1 = 1, and Fn = Fn − 1 + Fn − 2 ...
随机推荐
- Causal Inference
目录 Standardization 非参数情况 Censoring 参数模型 Time-varying 静态 IP weighting 无参数 Censoring 参数模型 censoring 条件 ...
- MQ消费失败,自动重试思路
在遇到与第三方系统做对接时,MQ无疑是非常好的解决方案(解耦.异步).但是如果引入MQ组件,随之要考虑的问题就变多了,如何保证MQ消息能够正常被业务消费.所以引入MQ消费失败情况下,自动重试功能是非常 ...
- Java EE数据持久化框架笔记 • 【目录】
章节 内容 实践练习 Java EE数据持久化框架作业目录(作业笔记) 第1章 Java EE数据持久化框架笔记 • [第1章 MyBatis入门] 第2章 Java EE数据持久化框架笔记 • [第 ...
- Java初学者作业——实现控制台的猜数字游戏。游戏运行时产生一个1~100之间的随机数字
返回本章节 返回作业目录 需求说明: (1)实现控制台的猜数字游戏.游戏运行时产生一个1-100之间的随机数字 (2)要求用户从控制台输入数字,若输入的数字比随机数小,则输出"太小了,再大一 ...
- Ubuntu16.04下,rabbimq集群搭建
rabbitmq作为企业级的消息队列,功能很齐全,既可以作为单一的部署模式,又可以做集群的部署模式 单一部署就不说了,就是在一台服务器上部署rabbitmq消息队列,可以参考我的博客:Ubuntu16 ...
- Java如何打好牢固的基础?
如果纯粹是为了学Java,那么不建议阅读本文,因为本文不是从理论和教科书的角度讲述如何打好java基础,而是会从"快速用java挣钱"这个角度,讲边学.边做项目和边提升的方法. 在 ...
- centos6.5-搭建LNMP
安装LNMP 一.安装nginx 1.安装相关组件 yum -y install pcre-devel zlib-devel 2.创建启动用户 useradd -M -s /sbin/nologin ...
- JMeter_响应数据为空以及中文乱码
一.响应数据为空 最近做测试接口,使用同样的请求方式.地址.参数和header,在postman中能正常响应,接收数据的也正常,但是在Jmeter中,虽然响应正常,但是响应数据却为空! Jmeter接 ...
- vue中把一个事件绑定到子组件上
官网上是这样描述的 你可能有很多次想要在一个组件的根元素上直接监听一个原生事件.这时,你可以使用 v-on的 .native 修饰符 父组件App.vue <template> <d ...
- 乒乓球队比赛,甲队有abc三人,乙队有xyz三人。 抽签得出比赛名单:a不和x比,c不和x,z比, 利用集合求出比赛名单
import java.util.HashMap; import java.util.Map; /** * 乒乓球队比赛,甲队有abc三人,乙队有xyz三人. * 抽签得出比赛名单:a不和x比,c不和 ...