cccc L2-018. 多项式A除以B

点击打开链接

【转自   Daemoonn   】

直接看到这题,我是没看懂的。然后就放哪里,没有写。后来看了多项式除法的一个视频,(网易公开课里面的)才会多项式除法。然后发现Daemoonn 写的比较清楚,好记。 拿来做模板吧。

计算

{\displaystyle {\frac {x^{3}-12x^{2}-42}{x-3}}.}{\frac {x^{3}-12x^{2}-42}{x-3}}.

把被除式、除式按某个字母作降幂排列,并把所缺的项用零补齐,写成以下这种形式:

{\displaystyle {\frac {x^{3}-12x^{2}+0x-42}{x-3}}.}{\frac {x^{3}-12x^{2}+0x-42}{x-3}}.

然后商和余数可以这样计算:

  1. 将分子的第一项除以分母的最高次项(即次数最高的项,此处为x)。结果写在横线之上(x3 ÷ x = x2).
    {\displaystyle {
    x2x3)x312x2+0x42¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯
    }} {\begin{matrix}x^{2}\\\qquad \qquad \quad x-3{\overline {)x^{3}-12x^{2}+0x-42}}\end{matrix}}
  2. 将分母乘以刚得到结果(最终商的第一项),乘积写在分子前两项之下(同类项对齐) (x2 · (x − 3) = x3 − 3x2).
    {\displaystyle {
    x2x3)x312x2+0x42¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯x33x2
    }} {\begin{matrix}x^{2}\\\qquad \qquad \quad x-3{\overline {)x^{3}-12x^{2}+0x-42}}\\\qquad \;\;x^{3}-3x^{2}\end{matrix}}
  3. 从分子的相应项中减去刚得到的乘积(消去相等项,把不相等的项结合起来),结果写在下面。((x3 − 12x2) − (x3 − 3x2) = −12x2 + 3x2 = −9x2)然后,将分子的下一项“拿下来”。
    {\displaystyle {
    x2x3)x312x2+0x42¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯x33x29x2+0x
    }} {\begin{matrix}x^{2}\\\qquad \qquad \quad x-3{\overline {)x^{3}-12x^{2}+0x-42}}\\\qquad \;\;{\underline {x^{3}-3x^{2}}}\\\qquad \qquad \qquad \quad \;-9x^{2}+0x\end{matrix}}
  4. 把减得的差当作新的被除式,重复前三步(直到余式为零或余式的次数低于除式的次数时为止.被除式=除式×商式+余式 )
    {\displaystyle {
    x29xx3)x312x2+0x42¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯x33x29x2+0x9x2+27x27x42
    }} {\begin{matrix}\;x^{2}-9x\\\qquad \quad x-3{\overline {)x^{3}-12x^{2}+0x-42}}\\\;\;{\underline {\;\;x^{3}-\;\;3x^{2}}}\\\qquad \qquad \quad \;-9x^{2}+0x\\\qquad \qquad \quad \;{\underline {-9x^{2}+27x}}\\\qquad \qquad \qquad \qquad \qquad -27x-42\end{matrix}}
  5. 重复第四步。这次没什么可以“拿下来”了。
    {\displaystyle {
    x29x27x3)x312x2+0x42¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯x33x29x2+0x9x2+27x27x4227x+81123
    }} {\begin{matrix}\qquad \quad \;\,x^{2}\;-9x\quad -27\\\qquad \quad x-3{\overline {)x^{3}-12x^{2}+0x-42}}\\\;\;{\underline {\;\;x^{3}-\;\;3x^{2}}}\\\qquad \qquad \quad \;-9x^{2}+0x\\\qquad \qquad \quad \;{\underline {-9x^{2}+27x}}\\\qquad \qquad \qquad \qquad \qquad -27x-42\\\qquad \qquad \qquad \qquad \qquad {\underline {-27x+81}}\\\qquad \qquad \qquad \qquad \qquad \qquad \;\;-123\end{matrix}}

横线之上的多项式即为商,而剩下的 (−123) 就是余数。

{\displaystyle {\frac {x^{3}-12x^{2}-42}{x-3}}=\underbrace {x^{2}-9x-27} _{q(x)}\underbrace {-{\frac {123}{x-3}}} _{r(x)/g(x)}}{\frac {x^{3}-12x^{2}-42}{x-3}}=\underbrace {x^{2}-9x-27} _{q(x)}\underbrace {-{\frac {123}{x-3}}} _{r(x)/g(x)}

算数的长除法可以看做以上算法的一个特殊情形,即所有 x 被替换为10的情形。

除法变换[编辑]

使用多项式长除法可以将一个多项式写成 除数-商 的形式(经常很有用)。 考虑多项式 P(x), D(x) ((D)的次数 < (P)的次数)。 然后,对某个商多项式 Q(x) 和余数多项式 R(x) ((R)的系数 < (D)的系数),

{\displaystyle {\frac {P(x)}{D(x)}}=Q(x)+{\frac {R(x)}{D(x)}}\implies P(x)=D(x)Q(x)+R(x).}{\frac {P(x)}{D(x)}}=Q(x)+{\frac {R(x)}{D(x)}}\implies P(x)=D(x)Q(x)+R(x).

这种变换叫做除法变换,是从算数等式 {\displaystyle {\mathrm {dividend} =\mathrm {divisor} \times \mathrm {quotient} +\mathrm {remainder} }}{\mathrm {dividend} =\mathrm {divisor} \times \mathrm {quotient} +\mathrm {remainder} }.[1] 得到的。

应用[编辑]

多项式的因式分解[编辑]

有时某个多项式的一或多个根已知,可能是使用有理数根定理得到的。如果一个{\displaystyle n}n次多项式 {\displaystyle P(x)}P(x)的一个根{\displaystyle r}r已知,那么{\displaystyle P(x)}P(x) 可以使用多项式长除法因式分解为{\displaystyle (x-r)Q(x)}{\displaystyle (x-r)Q(x)}的形式,其中{\displaystyle Q(x)}Q(x)是一个{\displaystyle n-1}n-1次的多项式。简单来说,{\displaystyle Q(x)}Q(x)就是长除法的商,而又知{\displaystyle r}r{\displaystyle P(x)}P(x)的一个根、余式必定为零。

相似地,如果不止一个根是已知的,比如已知{\displaystyle r}r{\displaystyle s}s这两个,那么可以先从{\displaystyle P(x)}P(x)中除掉线性因子{\displaystyle x-r}{\displaystyle x-r}得到{\displaystyle Q(x)}Q(x),再从{\displaystyle Q(x)}Q(x)中除掉 {\displaystyle x-s}{\displaystyle x-s},以此类推。或者可以一次性地除掉二次因子{\displaystyle x^{2}-(r+s)x+rs}x^{2}-(r+s)x+rs

使用这种方法,有时超过四次的多项式的所有根都可以求得,虽然这并不总是可能的。例如,如果有理数根定理可以用来求得一个五次方程的一个(比例)根,它就可以被除掉以得到一个四次商式;然后使用四次方程求根的显式公式求得剩余的根。

寻找多项式的切线[编辑]

多项式长除法可以用来在给定点上查找给定多项式的切线方程。[2] 如果 R(x) 是 P(x)/(x-r)2 的余式——也即,除以 x2-2rx+r2——那么在 x=r 处 P(x) 的切线方程是 y=R(x),不论 r 是否是 P(x) 的根。

#include<iostream>
#include<string>
#include<stdio.h>
#include<string.h>
#include<map>
#include<queue>
#include<math.h>
#include<algorithm>
using namespace std;
const int maxn=1e6+100;
int x,lena,lenb,maxa=-1,maxb=-1,cntc,cnta;
double y,a[maxn],b[maxn],c[maxn];
int input(int len,double *arr, int *maxx){
    for(int i=0;i<len;++i){
        scanf("%d%lf",&x,&y);
        arr[x]=y;
        *maxx=max(*maxx,x);
    }

}
void clearzoro(int &cnt,int be,double *arr){
    cnt=0;
    for(int i=be;i>=0;--i){
        if(!fabs(arr[i])<1e-8)
            fabs(arr[i])<0.05?arr[i]=0.0:cnt++;
    }
}
void output(int cnt,int be,double *arr){
    if(cnt==0) puts("0 0 0.0");
    else {
        printf("%d",cnt);
        for(int i=be;i>=0;--i){
            if(!fabs(arr[i])<1e-8) printf(" %d %.1lf",i,arr[i]);
        }
        puts("");
    }
}

int main(){

    scanf("%d",&lena);
    input(lena,a,&maxa);
    scanf("%d",&lenb);
    input(lenb,b,&maxb);
    for(int i=maxa;i>=maxb;--i){
        c[i-maxb]=a[i]/b[maxb];
        for(int j=maxb;j>=0;--j)
            a[j+i-maxb]-=b[j]*c[i-maxb];
    }
    clearzoro(cntc,maxa-maxb,c);
    clearzoro(cnta,maxb,a);
    output(cntc,maxa-maxb,c);
    output(cnta,maxb-1,a);
    return 0;
}


  • 0
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值