首页 > 其他分享 >多项式从入门到进门

多项式从入门到进门

时间:2024-02-16 12:23:01浏览次数:29  
标签:right frac 入门 多项式 sum cdots n2 进门

多项式全家福

多项式

一个以 \(x\) 为变量的多项式定义在一个代数域 \(F\) 上,将函数 \(A(x)\) 表示为形式和:

\[A(x)=\sum\limits_{i=0}^{n-1}a_ix^i \]

  • 我们称 \(a_0,a_1,\cdots,a_n\) 为多项式的系数,所有系数都属于数域 \(\mathbb F\)。

如果一个多项式的最高次的非零系数是 \(k\),则称 \(A(x)\) 的次数为 \(k\)。任何严格大于一个多项式次数的整数都是该多项式的次数界。因此,对于次数界为 \(n\) 的多项式 \(C(x)\),其次数可以是 \(0\sim n-1\) 之间的整数。

我们在多项式上可以定义很多不同的运算。

多项式加法

  • 如果 \(A(x)\) 和 \(B(x)\) 都是次数界为 \(n\) 的多项式,那么他们的和也是一个次数界为 \(n\) 的多项式 \(C(x)\)。

对于所有属于定义域的 \(x\),都有 \(C(x)=A(x)+B(x)\),即:

\[A(x)=\sum\limits_{i=0}^{n-1}a_ix^i \]

\[B(x)=\sum\limits_{i=0}^{n-1}b_ix^i \]

则有

\[C(x)=\sum\limits_{i=0}^{n-1}C_ix^i \]

其中

\[c_i=a_i+b_i \]


多项式乘法

  • 如果 \(A(x)\) 是次数界为 \(n\) 的多项式,\(B(x)\) 是次数界为 \(m\) 的多项式,那么他们的积是一个次数界为 \(n+m\) 的多项式 \(C(x)\)。其中:

\[c_i=\sum\limits_{j=0}^ia_{j}b_{i-j} \]


多项式的表示

系数表达

对于一个次数界为 \(n\) 的多项式 \(A(x)\),其系数表达式为一个由系数组成得到的向量:

\[a=(a_0,a_1,\cdots,a_{n-1}) \]

  • 我们可以用秦久韶算法在 \(O(n)\) 时间内求出多项式在给定点 \(x_0\) 的值,即:

\[A(x_0)=a_0+x_0(a_1+x_0(a_2+\cdots+x_0(a_{n-2}+x_0a_{n-1})\cdots)) \]

类似的,对于两个分别用系数向量 \(a=(a_0,a_1,\cdots,a_{n-1}),b=(b_0,b_1,\cdots,b_{n-1})\) 表示的多项式进行相加时,所需的时间是
\(O(n)\),我们只用输出系数向量 \(c=(c_0,c_1,\cdots,c_{n-1})\),其中 \(c_i=a_i+b_i\)。

乘法同理,此时 \(c\) 也称为输入向量 \(a,b\) 的卷积,记为 \(c=a\otimes b\)。

点值表达

  • 一个次数界为 \(n\) 的多项式的点值表达就是一个有 \(n\) 个点值对所组成的集合:

\[\{(x_0,y_0),(x_1,y_1),\cdots,(x_{n-1},y_{n-1})\} \]

使得对 \(k=0,1,\cdots,n-1\) 所有 \(x_k\) 各不相同且 \(y_k=A(x_k)\)。

一个多项式可以有很多不同的点值表达,因为可以采用 \(n\) 个不同的点构成的集合作为这种表示方法的基。

朴素的求值是 \(O(n^2)\) 的。

求值的逆称为插值。当插值多项式的次数界等于已知的点值对的数目时,插值才是明确的。

我们可以在用拉格朗日插值在 \(O(n^2)\) 内插值。

  • 以上求值和插值可以将多项式的系数表达和点值表达进行相互转化,上面给出的算法的时间复杂度是 \(O(n^2)\),但我们可以巧妙地选取 \(x_k\) 来加速这一过程,使其运行时间变为 \(O(n\log n)\)。

对于许多多项式相关的操作,点值表达式是十分便利的。

对于加法,如果 \(C(x)=A(x)+B(x)\),且点值表达分别为:

\[\{(x_0,y_0),(x_1,y_1),\cdots,(x_{n-1},y_{n-1})\} \]

\[\{(x_0,y'_0),(x_1,y'_1),\cdots,(x_{n-1},y'_{n-1})\} \]

则 \(C\) 的点值表达为:

\[\{(x_0,y_0+y'_0),(x_1,y_1+y'_1),\cdots,(x_{n-1},y_{n-1}+y'_{n-1})\} \]

乘法同理,此时需要 \(2n\) 个点才能插出 \(C\):

\[\{(x_0,y_0y'_0),(x_1,y_1y'_1),\cdots,(x_{2n-1},y_{2n-1}y'_{2n-1})\} \]

时间复杂度为 \(O(n)\)。

  • 最后,我们考虑一个采用点值表达的多项式,如何求其在某个新点上的值。最简单的方法是把该多项式转成系数形式表达,然后在新点处求值。

DFT&FFT&IDFT

单位根

  • 在复数域下,满足 \(w^n=1\) 的 \(w\) 被称为 \(n\) 次单位根。

根据代数基本定理,\(n\) 次单位根。一共有 \(n\) 个,这些根为 \(e^{\frac{2\pi ik}{n}}\)。

\(e^{\frac{2\pi i}{n}}\) 为主 \(n\) 次单位根,所有其他 \(n\) 次单位复数根都是\(w_n\)的幂次。

这 \(n\) 个单位复数根在乘法意义下形成了一个群,而且均匀分布在以复平面的原点为圆心的单位半径的圆周上。

  • 消去引理:对任何自然数 \(n,k,d\),都有:

\[w_{dn}^{dk}=w_n^k \]


DFT

  • 我们希望计算次数界为 \(n\) 的多项式 \(A(x)\) 在 \(w_n^0,w_n^1,\cdots,w_n^{n-1}\) 处的值。

对于 \(k=0,1,\cdots,n-1\),定义结果 \(y_k\):

\[y_k=A(w_n^k)=\sum\limits_{i=0}^{n-1}a_iw_n^{ki} \]

向量 \(y=(y_0,y_1,\cdots,y_{n-1})\) 即为系数向量 \(a\) 的 DFT,也记为 \(y=DFT_n(a)\)。


FFT

利用单位复数根的特殊性质,我们可以在 \(O(n\log n)\) 的时间内计算出 \(DFT_n(a)\)。设 \(n\) 为 \(2\) 的幂次。

  • 我们利用分治:

令 \(a=(a_0,a_2,\cdots,a_{n-1}),a_1=(a_0,a_2,\cdots,a_{n-2}),a=(a_1,a_2,\cdots,a_{n-1})\)

对于 \(k<\frac{n}{2}\),我们有:

\[\begin{aligned}y_k&=A(w_n^k)\\&=\sum\limits_{i=0}^{n-1}a_iw_n^{ki}\\&=\sum\limits_{i=0}^{\frac{n}{2}-1}a_{2i}w_n^{2ki}+\sum\limits_{i=0}^{\frac{n}{2}-1}a_{2i+1}w_n^{2ki+k}\\&=\sum\limits_{i=0}^{\frac{n}{2}-1}a_{2i}w_n^{2ki}+w_n^k\sum\limits_{i=0}^{\frac{n}{2}-1}a_{2i+1}w_n^{2ki}\\&=\sum\limits_{i=0}^{\frac{n}{2}-1}a_{2i}w_{\frac{n}{2}}^{ki}+w_n^k\sum\limits_{i=0}^{\frac{n}{2}-1}a_{2i+1}w_{\frac{n}{2}}^{ki}\\&={y_1}_k+w_n^k{y_2}_k\end{aligned} \]

对于 \(k\geq \frac{n}{2}\),我们有:

\[\begin{aligned}A(w_n^k)&=\sum_{i=0}^{n-1}a_iw_n^{ki}\\&=\sum_{i=0}^{\frac n2-1}a_{2i}w_n^{2ki}+\sum_{i=0}^{\frac n2-1}a_{2i+1}w_n^{2ki+k}\\&=\sum_{i=0}^{\frac n2-1}a_{2i}w_n^{2ki}+w_n^k\sum_{i=0}^{\frac n2-1}a_{2i+1}w_n^{2ki}\\&=\sum_{i=0}^{\frac n2-1}{a_1}_{i}w_{\frac n2}^{ki}+w_n^k\sum_{i=0}^{\frac n2-1}{a_2}_{i}w_{\frac n2}^{ki}\\&=\sum_{i=0}^{\frac n2-1}{a_1}_{i}w_{\frac n2}^{(k-\frac n2)i}+w_n^k\sum_{i=0}^{\frac n2-1}{a_2}_{i}w_{\frac n2}^{(k-\frac n2)i}\\&={y_1}_{k-\frac n2}+w_n^k{y_2}_{k-\frac n2}\\&={y_1}_{k-\frac n2}-w_n^{k-\frac n2}{y_2}_{k-\frac n2} \end{aligned}\]

这样我们把 \(y_1,y_2\) 合并为 \(y_3\) 的时间复杂度是 \(O(n)\)。

所以总的时间复杂度为:

\[T(n)=2T(\dfrac{n}{2})+O(n)=O(n\log n) \]


IDFT

通过推导公式,我们可以得到:

\[a_k=\dfrac{1}{k}\sum\limits_{i=0}^{n-1}y_iw_n^{-ki} \]

所以我们可以用类似 FFT 的方法在 \(O(n\log n)\) 的时间内求出 \(IDFT_n(y)\)。


多项式乘法

我们可以在 \(O(n)\) 时间内补零,\(O(n\log n)\)内求值,\(O(n)\) 内点值乘法,\(O(n\log n)\) 内插值,所以我们可以在 \(O(n\log n)\) 内求出 \(a\otimes b\),即:

\[a\otimes b=IDFT_{2n}\big(DFT_{2n}(a)\cdot DFT_{2n}(a)\big) \]


蝶形变换

我们发现,递归时 \(a\) 是长这样的:

\[\left[0\quad1\quad2\quad3\quad4\quad5\quad6\quad7\right] \]

\[\left[0\quad2\quad4\quad6\right]\ \left[1\quad3\quad5\quad7\right] \]

\[\left[0\quad4\right]\ \left[2\quad6\right]\ \left[1\quad5\right]\ \left[3\quad7\right] \]

\[\left[0\right]\ \left[4\right]\ \left[2\right]\ \left[6\right]\ \left[1\right]\ \left[5\right]\ \left[3\right]\ \left[7\right] \]

  • 注意到最后的 \(a_i\) 是原来的 \(a_{rev(i)}\),所以我们可以交换 \(a_i\) 和 \(a_{rev(i)}\),然后一层层来做以减小常数。

三次变两次

按照上面的做法,我们要分别先求出 \(A(x),B(x)\) 的卷积,把它们分别FFT,然后对应每项乘起来,最后再逆FFT回来。

  • 来回一共进行了三次FFT,感觉这样是很不优的。

我们可以把 \(B(x)\) 放到 \(A(x)\) 的虚部上面去,求得 \(A(x)^2\),然后把它的虚部取出来除以二就是答案了。

  • 证明:

\[(a+bi)^2=(a^2-b^2)+(2abi) \]

这样我们就把常数优化到原来的 \(\frac{2}{3}\)。


NTT

  • 在某些时候,我们需要求模 \(p\) 意义下的卷积。

先求出 \(p\) 的原根 \(g\),不难发现 \(g^{\frac{p}{n-1}}\) 与 \(w_n\) 的性质类似,所以我们可以用 \(g^{\frac{p}{n-1}}\) 来代替 \(w_n\)。


多项式求导

  • 给定 \(A(x)=\sum\limits_{i\geq 0} a_ix^i\),则其导为:

\[A^{\prime}(x)=\sum\limits_{i\geq 1}ia_ix^{i-1} \]


多项式积分

  • 给定 \(A(x)=\sum\limits_{i\geq 0} a_ix^i\),则其积分为:

\[\int A(x)=\sum\limits_{i\geq 1}\dfrac{a_{i-1}}{i}x^i \]


多项式牛顿迭代

  • 已知 \(g(x)\bmod x^n\),求 \(f(x)\) 使得 \(g(f(x))\equiv0\pmod{x^n}\)。

考虑倍增。

首先当 \(n=1\) 时,\(\left[x^{0}\right]g(f(x))=0\) 的解需要单独求出。

将 \(g(f(x))\) 在 \(f_{0}(x)\) 处进行泰勒展开,有:

\[\sum_{i=0}^{+\infty}\frac{g^{(i)}(f_{0}(x))}{i!}(f(x)-f_{0}(x))^{i}\equiv 0\pmod{x^{n}} \]

因为 \(f(x)-f_{0}(x)\) 的最低非零项次数最低为 \(\lceil\frac{n}{2}\rceil\),故有:

\[\forall 2\leqslant i:((f(x)-f_{0}(x))^{i}\equiv 0\pmod{x^{n}} \]

则:

\[\sum_{i=0}^{+\infty}\frac{g^{(i)}(f_{0}(x))}{i!}(f(x)-f_{0}(x))^{i}\equiv g(f_{0}(x))+g'(f_{0}(x))(f(x)-f_{0}(x))\equiv 0\pmod{x^{n}} \]

\[f(x)\equiv f_{0}(x)-\frac{g(f_{0}(x))}{g'(f_{0}(x))}\pmod{x^{n}} \]


多项式求逆

多项式 \(A(x)\) 存在乘法逆元的充要条件是其常数项存在乘法逆元。

  • 设给定函数为 \(h(x)\),有方程:

\[g(f(x))=\frac{1}{f(x)}-h(x)\equiv 0\pmod{x^{n}} \]

应用牛迭可得:

\[\begin{aligned}f(x)&\equiv f_{0}(x)-\frac{\frac{1}{f_{0}(x)}-h(x)}{-\frac{1}{f_{0}^{2}(x)}}&\pmod{x^{n}}\\&\equiv f_{0}(x)(2-f_{0}(x)h(x))&\pmod{x^{n}} \end{aligned}\]

时间复杂度为:

\[T(n)=O(n\log n)+T\left(\dfrac{n}{2}\right)=O(n\log n) \]


多项式开根

  • 设给定函数为 \(h(x)\),有方程:

\[g(f(x))=f^{2}(x)-h(x)\equiv 0\pmod{x^{n}} \]

应用牛迭可得:

\[\begin{aligned}f(x)&\equiv f_{0}(x)-\frac{f_{0}^{2}(x)-h(x)}{2f_{0}(x)}&\pmod{x^{n}}\\&\equiv\frac{f_{0}^{2}(x)+h(x)}{2f_{0}(x)}&\pmod{x^{n}} \end{aligned}\]

时间复杂度为:

\[T(n)=O(n\log n)+T\left(\dfrac{n}{2}\right)=O(n\log n) \]


多项式exp

  • 设给定函数为 \(h(x)\),有方程:

\(g(f(x))=\ln{f(x)}-h(x)\pmod{x^{n}}\)

应用牛迭可得:

\[\begin{aligned}f(x)&\equiv f_{0}(x)-\frac{\ln{f_{0}(x)}-h(x)}{\frac{1}{f_{0}(x)}}&\pmod{x^{n}}\\&\equiv f_{0}(x)(1-\ln{f_{0}(x)+h(x)})&\pmod{x^{n}}\end{aligned} \]

时间复杂度为 \(O(n\log n)\)。


多项式快速幂

  • 若 \(F(0)=1\),就可以直接用 \(\ln+\exp\) 来搞,即:

\[F(x)^k= \text e^{k\ln F(x)} \]

  • 若 \(F(0)\neq1\) 可以考虑将 \(F(x)\) 降次,然后再升次。

具体来讲,我们要找出最小的 \(t\),满足 \(F(x)\) 的 \(t\) 次项不为 \(0\),那么:

\[F(x)^k=\left(\frac{F(x)}{x^t} \right)^kx^{tk} \]

时间复杂度为 \(O(n\log n)\)。


多项式除法

  • 给定多项式 \(f(x),g(x)\),求 \(g(x)\) 除 \(f(x)\) 的商式 \(Q(x)\) 和余式 \(R(x)\)。

发现若能消除 \(R(x)\) 的影响则可直接多项式求逆解决。

考虑构造变换 \(f^{R}(x)=x^{\operatorname{deg}{f}}f(\frac{1}{x})\)
观察可知其实质为反转 \(f(x)\) 的系数。

设 \(n=\operatorname{deg}{f},m=\operatorname{deg}{g}\)。

将 \(f(x)=Q(x)g(x)+R(x)\) 中的 \(x\) 替换成 \(\frac{1}{x}\) 并将其两边都乘上 \(x^{n}\),得到:

\[\begin{aligned}x^{n}f(\frac{1}{x})&=x^{n-m}Q(\frac{1}{x})x^{m}g(\frac{1}{x})+x^{n-m+1}x^{m-1}R(\frac{1}{x})\\f^{R}(x)&=Q^{R}(x)g^{R}(x)+x^{n-m+1}R^{R}(x)\end{aligned} \]

注意到上式中 \(R^{R}(x)\) 的系数为 \(x^{n-m+1}\),则将其放到模 \(x^{n-m+1}\) 意义下即可消除 \(R^{R}(x)\) 带来的影响。

又因 \(Q^{R}(x)\) 的次数为 \((n-m)<(n-m+1)\),故 \(Q^{R}(x)\) 不会受到影响。

则:

\[f^{R}(x)\equiv Q^{R}(x)g^{R}(x)\pmod{x^{n-m+1}} \]

使用多项式求逆即可求出 \(Q(x)\),将其反代即可得到 \(R(x)\)。

时间复杂度 \(O(n\log{n})\)。

标签:right,frac,入门,多项式,sum,cdots,n2,进门
From: https://www.cnblogs.com/QcpyWcpyQ/p/18017035

相关文章

  • 生成函数从入门到进门
    引入先看下面这个例子:\[(1+a_1x)\times(1+a_2x)\times\cdots\times(1+a_nx)\]拆括号得:\[1+(a_1+a_2+\cdots+a_n)x+(a_1a_2+a_1a_3+\cdots+a_{n-1}a_n)x^2+\cdots+(a_1a_2\cdotsa_n)x^n\]其中\(x^2\)的系数包含了从\(n\)个元素\(\{a_1,a_2,\cdots,a_n\}\)中选取两个的......
  • 概率期望从入门到进门
    概率的线性性定义:\(\mathbb{E}(X)=\sum_i\timesP(X=i)\)。其中\(x\)为变量。线性性\[\begin{aligned}\mathbb{E}(aX+bY)&=\sumi\timesP(aX+bY=i)\\&=\sumi\sum_j\sum_k[j+k=i]P(aX=j)P(bY=k)\\&=\sum_j\sum_k(j+k)P(aX=j)\cdotP(bY=k)\\&......
  • HydroOJ 从入门到入土(13)批量修改题号前缀
    题库的管理,无论是用前缀来分组,还是用域来分组,都有不好管理的地方,尤其是题号。有的时候导入了一堆题,导入完发现题号不是自己想要的,但删起来很麻烦,一个一个改更不现实,真是欲哭无泪。本文主要记录了一次批量修改题号前缀的过程,仅供参考。修改中涉及数据库操作,修改前一定要现在虚......
  • 拓扑排序入门
    目录写在前面一些概念算法步骤字典序最大/最小的拓扑序列?模板例题3704.排队家谱树奖金P1983[NOIP2013普及组]车站分级1639.拓扑顺序写在前面昨晚cfdiv3的F就是一道基本上可以说板子的拓扑排序的题目,没有做出来感觉图论很早之前就看了,但是基本没有刷过什么题,开始补一下图论......
  • 掌握C语言文件操作:从入门到精通的完整指南!
    ✨✨欢迎大家来到贝蒂大讲堂✨✨......
  • pytorch深度学习入门(8)之-Torchaudio使用Tacotron2 文本转语音
    https://blog.csdn.net/ajunbin859/article/details/134380417?ops_request_misc=&request_id=&biz_id=102&utm_term=pytorch%E7%89%88%E6%9C%AC%E7%9A%84tacotron%E8%AF%A6%E7%BB%86%E5%AE%89%E8%A3%85%E6%95%99%E7%A8%8B&utm_medium=distribute.pc_search_r......
  • day04_操作系统入门
    今日笔记学操作系统基础概念linux系统linux系统(centos)+vmware安装起来(网络配置,磁盘分区)ubuntu安装xshell服务器的远程连接服务器网站的前后端,数据库app的前后端,数据库微信、腾讯微信的服务器移动端设备上,安装的微信客户端在线笔记笔记对运维来说,就是一个宝藏,mar......
  • day21_乌班图入门
    .请解释yum缓存,如何理解、如何管理去网络源下载软件rpm包,会涉及网络延时,网络资源消耗1.解决,关于yum缓存包的理解(自己搭建yum仓库)11.当你拿到一个初始化的机器,默认安装的软件(centos上的rpm格式的软件)数量可能很少导致你后期使用各种工具,会报错,比如python调用gzip解压缩功能s......
  • Python语言程序设计入门教程
      目  录第一章、概述    1.Python是什么    2.Python语言的特点    3.Python语言的缺点    4.Python程序的执行过程10   5.安装Python11  6.运行Python程序17        7.Python集成开发环境21  第二章、......
  • P4512 【模板】多项式除法
    为什么不能直接用\(F(x)\timesG(x)^{-1}\)做?\(G(x)^{-1}\)是模\(x^{m+1}\)意义下的,\(n-m>m\)时得到的\(Q(x)\)就是错的。记\(F'(x)\)为\(F(x)\)系数翻转后的多项式,即若\(F(x)=\sum\limits_{i=0}^nf_ix^i\),则\(F'(x)=\sum\limits_{i=0}^nf_{n......