0. Intro

\[f_n=\begin{cases}
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(x)=\sum_{i=0}^{\infty}a_ix^i=a_0+a_1x+a_2x^2+\cdots
\]

为了熟悉生成函数,先来看一个很基础的例子:

已知数列 \(f_n=1\) ,求 \(f\) 的生成函数 \(F(x)\) 。

直接代到定义式里就好了

\[F(x)=\sum_{i=0}^{\infty}f_ix^i=\sum_{i=0}^{\infty}x^i
\]

发现这里其实就是一个等比数列求和

\[F(x)=\lim_{i\rightarrow \infty}\dfrac{1-x^i}{1-x}
\]

研究生成函数时我们都假设级数收敛

如果你不知道级数收敛是什么意思 只需要知道生成函数中的 \(x\) 没有实际意义 所以我们可以任意取值 所以不妨设 \(0<x<1\)

那么当 \(i\) 趋向于无穷大时,\(x^i\) 显然趋于 \(0\)

于是就得到了一个很简单的式子

\[F(x)=\dfrac1{1-x}
\]

同理可以得到三个关于等比数列的生成函数的结论:

数列 \(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数列通项公式

\[f_n=\begin{cases}
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)\) 求出来

\[\begin{matrix}
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}\)

要从生成函数反推出原数列 我们只知道这三个相关的结论

那么我们以这三个结论为目标试着做一些代数变形

\[F(x)=\dfrac1{1-x-x^2}
\]

分母显然要降次

设方程 \(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)\)

\[F(x)=-\dfrac1{(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)\) 很接近了

先把最前面的负号乘进去

\[F(x)=\dfrac1{x_1-x_2}\cdot\left[-\dfrac1{x-x_1}-\left(-\dfrac1{x-x_2}\right)\right]
\]

易知 \(x_1x_2=-1\) ,所以 \(x_2=-\dfrac1{x_1},x_1=-\dfrac1{x_2}\)

\[F(x)=\dfrac1{x_1-x_2}\cdot\left[-\dfrac1{x-\frac1{-x_2}}-\left(-\dfrac1{x-\frac1{-x_1}}\right)\right]
\]

由结论三可知,对于数列 \(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(x)=\dfrac{H(x)-G(x)}{x_1-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\) 代入

\[f_n=\dfrac{\left(\frac{1+\sqrt5}2\right)^{n+1}-\left(\frac{1-\sqrt5}2\right)^{n+1}}{\sqrt5}
\]

这样就得到了通项公式

而如果是开头那个版本的斐波拉契数列:

\[f_n=\begin{cases}
0 & (n=0) \\
1 & (n=1) \\
f_{n-1}+f_{n-2} & (n>1)
\end{cases}\]

它的通项公式就是

\[f_n=\dfrac{\left(\frac{1+\sqrt5}2\right)^n-\left(\frac{1-\sqrt5}2\right)^n}{\sqrt5}
\]

3. 总结

(与前面的内容可能有些出入)

数列 \(a_0,a_1,a_2,a_3,\cdots\) 的普通型生成函数(OGF)(以下称为生成函数)为

\[F(x)=\sum_{i=0}^{\infty}a_ix^i=a_0+a_1x+a_2x^2+\cdots
\]

首项为 \(a\) ,公比为 \(q\) 的等比数列(即 \(a,qa,q^2a,q^3a,\cdots\) )的生成函数为

\[F(x)=\dfrac{a}{1-qx}
\]

当 \(a=q\) 时可知数列 \(q,q^2,q^3,\cdots\) 的生成函数为

\[F(x)=-\dfrac1{x-\frac1q}
\]

这个结论可以用来推导斐波拉契数列的通项公式

斐波拉契数列的递推式:

\[f_n=\begin{cases}
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(x)=\dfrac1{1-x-x^2}=\dfrac1{\sqrt5}\left(-\dfrac1{x-\frac{-1+\sqrt5}2}+\dfrac1{x-\frac{-1-\sqrt5}2}\right)
\]

斐波拉契数列的通项公式(这里 \(f_0=0,f_1=1\) )

\[f_n=\dfrac1{\sqrt5}\left[\left(\frac{1+\sqrt5}2\right)^n-\left(\frac{1-\sqrt5}2\right)^n\right]
\]

求Fibonacci数列通项公式的更多相关文章

  1. 用PL0语言求Fibonacci数列前m个中偶数位的数

    程序说明:求Fibonacci数列前m个中偶数位的数: 这是编译原理作业,本打算写 求Fibonacci数列前m个数:写了半天,不会写,就放弃了: 程序代码如下: var n1,n2,m,i; pro ...

  2. C++项目參考解答:求Fibonacci数列

    [项目:求Fibonacci数列] Fibonacci数列在计算科学.经济学等领域中广泛使用,其特点是:第一.二个数是1,从第3个数開始,每一个数是其前两个数之和.据此,这个数列为:1 1 2 3 5 ...

  3. 程序员面试题精选100题(16)-O(logn)求Fibonacci数列[算法]

    作者:何海涛 出处:http://zhedahht.blog.163.com/ 题目:定义Fibonacci数列如下: /  0                      n=0 f(n)=      ...

  4. 《面试题精选》15.O(logn)求Fibonacci数列

    题目:定义Fibonacci数列例如以下: /    0                      n=0 f(n)=      1                      n=1          ...

  5. 用Python实现求Fibonacci数列的第n项

    1. 背景——Fabonacci数列的介绍(摘自百度百科): 斐波那契数列(Fibonacci sequence),又称黄金分割数列.因数学家列昂纳多·斐波那契(Leonardoda Fibonacc ...

  6. 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) ...

  7. 牛客IOI周赛17-提高组 卷积 生成函数 多项式求逆 数列通项公式

    LINK:卷积 思考的时候 非常的片面 导致这道题没有推出来. 虽然想到了设生成函数 G(x)表示最后的答案的普通型生成函数 不过忘了化简 GG. 容易推出 \(G(x)=\frac{F(x)}{1- ...

  8. 16.O(logn)求Fibonacci数列[Fibonacci]

    [题目] log(n)时间Fib(n),本质log(n)求a^n. [代码]  C++ Code  12345678910111213141516171819202122232425262728293 ...

  9. POJ ---3070 (矩阵乘法求Fibonacci 数列)

    Fibonacci   Description In the Fibonacci integer sequence, F0 = 0, F1 = 1, and Fn = Fn − 1 + Fn − 2  ...

随机推荐

  1. 前端项目 node8升级到node16,代码升级汇总

    背景 公司的项目是vue项目,环境是node@8x版本的,最近我创建react hook的项目,发现至少需要node14才支持,打开官网才发现node都已经到16版本了.失策啊,失策.于是直接升级到最 ...

  2. spring事务失效的12种场景

    一 事务不生效 1.访问权限问题 java的访问权限主要有四种:private<default<protected<public. 把有某些事务方法,定义了错误的访问权限,就会导致事 ...

  3. Certified Adversarial Robustness via Randomized Smoothing

    目录 概 主要内容 定理1 代码 Cohen J., Rosenfeld E., Kolter J. Certified Adversarial Robustness via Randomized S ...

  4. linux - 运维知识

    使用nmap检测服务器端口安全性 https://blog.csdn.net/jayjaydream/article/details/108555250

  5. 论文翻译:2020_Generative Adversarial Network based Acoustic Echo Cancellation

    论文地址:http://www.interspeech2020.org/uploadfile/pdf/Thu-1-10-5.pdf 基于GAN的回声消除 摘要 生成对抗网络(GANs)已成为语音增强( ...

  6. SpringCloud集成Security安全(Eureka注册中心)

    1.说明 为了保护注册中心的服务安全, 避免恶意服务注册到Eureka, 需要对Eureka Server进行安全保护, 本文基于Spring Security方案, 为Eureka Server增加 ...

  7. Storm对DRPC权限控制Version1.0.1

    对Storm的DRPC进行权限控制, 并且设计相应的测试验证. 1.集群安装 请参考Storm集群安装Version1.0.1 2.使用DRPC功能 请参考Storm集群使用DRPC功能Version ...

  8. MyBatis 一级缓存实现详解及使用注意事项

    一级缓存介绍 在应用运行过程中,我们有可能在一次数据库会话中,执行多次查询条件完全相同的SQL,MyBatis提供了一级缓存的方案优化这部分场景,如果是相同的SQL语句,会优先命中一级缓存,避免直接对 ...

  9. CSS基础 元素整体透明效果(包含内容+背景及子元素)

    属性名:opacity:数字+px; 数字值取值0-1之间数字 数字值:1表示完全不透明 0表示完全透明使用后效果 html结构代码 <div class="box"> ...

  10. 初识python: random 模块

    random 顾名思义,就是取 随机数,需要导入random模块. import random 1.随机获取一个0到1之间的小数(不含首尾) print(random.random()) 2.随机获取 ...