《算法案例(二)秦九韶算法(精品).ppt》由会员分享,可在线阅读,更多相关《算法案例(二)秦九韶算法(精品).ppt(15页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、学习目标:学习目标:1 1、了解秦九韶算法的计算过程,并理解利用秦、了解秦九韶算法的计算过程,并理解利用秦九韶算法可以减少计算次数提高计算效率的实质。九韶算法可以减少计算次数提高计算效率的实质。2 2、模仿秦九韶计算方法,体会古人计算构思的、模仿秦九韶计算方法,体会古人计算构思的巧妙。巧妙。1 1、求两个数的最大公约数的两种方法分别是(、求两个数的最大公约数的两种方法分别是()和(和()。)。2 2、两个数、两个数2167221672,81278127的最大公约数是(的最大公约数是()A A、2709 B2709 B、2606 C2606 C、2703 D2703 D、27062706知识回顾
2、知识回顾问题问题1设计求多项式设计求多项式f(x)=2x5-5x4-4x3+3x2-6x+7当当x=5时的值的算法时的值的算法,并写出程序并写出程序.x=5f=2x5-5x4-4x3+3x2-6x+7PRINT fEND程序程序点评点评:上述算法一共做了上述算法一共做了15次乘法运算次乘法运算,5次次加法运算加法运算.优点是简单优点是简单,易懂易懂;缺点是不通用缺点是不通用,不能不能解决任意多项多求值问题解决任意多项多求值问题,而且计算效率不高而且计算效率不高.知识探究知识探究阅读教材阅读教材37页页39页内容,解决下列问题:页内容,解决下列问题:这析计算上述多项式的值这析计算上述多项式的值,
3、一共需要一共需要9次次乘法运算乘法运算,5次加法运算次加法运算.问题问题2有没有更高效的算法有没有更高效的算法?分析分析:计算计算x的幂时的幂时,可以利用前面的计算结可以利用前面的计算结果果,以减少计算量以减少计算量,即先计算即先计算x2,然后依次计算然后依次计算的值的值.第二种做法与第一种做法相比第二种做法与第一种做法相比,乘法的运乘法的运算次数减少了算次数减少了,因而能提高运算效率因而能提高运算效率.而且对于而且对于计算机来说计算机来说,做一次乘法所需的运算时间比做做一次乘法所需的运算时间比做一次加法要长得多一次加法要长得多,因此第二种做法能更快地因此第二种做法能更快地得到结果得到结果.问
4、题问题3能否探索更好的算法能否探索更好的算法,来解决任意多项式来解决任意多项式的求值问题的求值问题?f(x)=2x5-5x4-4x3+3x2-6x+7=(2x4-5x3-4x2+3x-6)x+7=(2x3-5x2-4x+3)x-6)x+7=(2x2-5x-4)x+3)x-6)x+7=(2x-5)x-4)x+3)x-6)x+7v0=2v1=v0 x-5=25-5=5v2=v1x-4=55-4=21v3=v2x+3=215+3=108v4=v3x-6=1085-6=534v5=v4x+7=5345+7=2677所以所以,当当x=5时时,多项式的值是多项式的值是2677.这种求多项式值的方法就叫这种
5、求多项式值的方法就叫秦九韶算法秦九韶算法.例例1:用秦九韶算法求多项式用秦九韶算法求多项式 f(x)=2x5-5x4-4x3+3x2-6x+7当当x=5时的值时的值.解法一解法一:首先将原多项式改写成如下形式首先将原多项式改写成如下形式:f(x)=(2x-5)x-4)x+3)x-6)x+7v0=2 v1=v0 x-5=25-5=5v2=v1x-4=55-4=21v3=v2x+3=215+3=108v4=v3x-6=1085-6=534v5=v4x+7=5345+7=2677所以所以,当当x=5时时,多多项式的值是项式的值是2677.然后由内向外逐层计算一次多项式的值然后由内向外逐层计算一次多项
6、式的值,即即2 -5 -4 3 -6 7x=5105252110510854053426702677所以所以,当当x=5时时,多项式的值是多项式的值是2677.原多项式原多项式的系数的系数多项式多项式的值的值.例例1:用秦九韶算法求多项式用秦九韶算法求多项式 f(x)=2x5-5x4-4x3+3x2-6x+7当当x=5时的值时的值.解法二解法二:列表列表22 -5 0 -4 3 -6 0 x=5105252512512160560830403034所以所以,当当x=5时时,多项式的值是多项式的值是15170.练一练练一练:用秦九韶算法求多项式用秦九韶算法求多项式 f(x)=2x6-5x5-4x
7、3+3x2-6x当当x=5时的值时的值.解解:原多项式先化为原多项式先化为:f(x)=2x6-5x5+0 x4-4x3+3x2-6x+0列表列表21517015170 注意注意:n次多项式有次多项式有n+1项项,因此缺少哪一项因此缺少哪一项应将其系数补应将其系数补0.f(x)=anxn+an-1xn-1+an-2xn-2+a1x+a0.我们可以改写成如下形式我们可以改写成如下形式:f(x)=(anx+an-1)x+an-2)x+a1)x+a0.求多项式的值时求多项式的值时,首先计算最内层括号内一首先计算最内层括号内一次多项式的值次多项式的值,即即 v1=anx+an-1,然后由内向外逐层计算一
8、次多项式的值然后由内向外逐层计算一次多项式的值,即即一般地一般地,对于一个对于一个n次多项式次多项式v2=v1x+an-2,v3=v2x+an-3,vn=vn-1x+a0.这样这样,求求n次多项式次多项式f(x)的值就转化为求的值就转化为求n个个一次多项式的值一次多项式的值.这种算法称为这种算法称为秦九韶算法秦九韶算法.点评点评:秦九韶算法是求一元多项式的秦九韶算法是求一元多项式的值的一种方法值的一种方法.它的特点是它的特点是:把求一个把求一个n次多项式的值次多项式的值转化为求转化为求n个一次多项式的值个一次多项式的值,通过这种转通过这种转化化,把运算的次数由至多把运算的次数由至多n(n+1)
9、/2次乘法次乘法运算和运算和n次加法运算次加法运算,减少为减少为n次乘法运算次乘法运算和和n次加法运算次加法运算,大大提高了运算效率大大提高了运算效率.v1=anx+an-1,v2=v1x+an-2,v3=v2x+an-3,vn=vn-1x+a0.观察上述秦九韶算法中的观察上述秦九韶算法中的n个一次式个一次式,可可见见vk的计算要用到的计算要用到vk-1的值的值.若令若令v0=an,得得v0=an,vK=vK-1x+an-k(k=1,2,n这是一个在秦九韶算法中反复执行的步这是一个在秦九韶算法中反复执行的步骤骤,因此可用循环结构来实现因此可用循环结构来实现.问题问题画出程序框图画出程序框图,表
10、示用秦九韶算法求表示用秦九韶算法求5次多次多项式项式f(x)=a5x5+a4x4+a3x3+a2x2+a1x+a0当当x=x0 (x0是任意实数是任意实数)时的值的过程时的值的过程,然后写出程序然后写出程序.否否程序框图程序框图开始开始输入输入a0,a1,a2,a3,a4,a5输入输入x0n5?n=1v=a5v=vx0+a5-nn=n+1输出输出v结束结束是是INPUT a0,a1,a2,a3,a4,a5INPUT x0n=1v=a5WHILE n=5 v=vx0+a5-n n=n+1WENDPRINT vEND程序程序达标检测达标检测1.已知已知f(x)=x5-4x4+2x2-5x+1,求求
11、f(3)的值的值.f(3)=-77f(3)=-772.2.用秦九韶算法计算多项式用秦九韶算法计算多项式f(x)=3xf(x)=3x6 6+4x+4x5 5+5x+5x4 4+6x+6x3 3+7x+7x2 2+8x+1+8x+1当当x=0.4x=0.4时的值时时的值时,需要需要做乘法和加法的次数分别是做乘法和加法的次数分别是()()A.6,6 B.5,6 C.5,5 D.6,5A.6,6 B.5,6 C.5,5 D.6,5A A3.用秦九韶算法求多项式用秦九韶算法求多项式f(x)=x4-2x3+3x2-7x-5当当x=4时的时的值值,给出如下数据给出如下数据:0 2 11 37 143 其运算过其运算过程中程中(包括最终结果包括最终结果)会出现的数有会出现的数有_(只填序号只填序号).5.利用秦九韶算法计算函数利用秦九韶算法计算函数f(x)=x+2x2+3x3+4x4+5x5的值时的值时,需要做加法需要做加法 乘法的次数分别为乘法的次数分别为_ _.454.用秦九韶算法求多项式用秦九韶算法求多项式f(x)=8x7+5x6+3x4+2x+1当当x=2时的值时的值.13971397课堂小结:课堂小结:1、秦九韶算法的方法和步骤、秦九韶算法的方法和步骤2、秦九韶算法的程序框图、秦九韶算法的程序框图作业:作业:P48 A组组 2 预习预习 进位制进位制
限制150内