1.3算法案例-秦九韶算法教学设计
1.3.2算法案例(秦九韶算法)
学生交流、补充回答自学指导中的问题,教师进行补充及纠正总结,引导学生加强对知识的理解深度。
1.强调利用常规自然的运算方法,运算量大,若用前面的计算结果,直接计算后面的式子,可以减少运算量,提高运算效率。
2.强调作为常识性的知识,让学生了解到计算机进行乘法运算比加法运算花的时间要长的多,故而在程序编写中,需要进行运算,尽量使用加法。
3.让学生明确秦九韶算法的作用和意义。
4.通过交流关于秦九韶的简介,突破本节课的情感态度与价值观目标,教师鼓励学生要增强学习数学的信心。附:
秦九韶(公元1202-1261),字道古,安岳人。秦九韶与李冶、杨辉、朱世杰并称宋元数学四大家。其父秦季栖,进士出身,官至上部郎中、秘书少监。秦九韶聪敏勤学。宋绍定四年(1231),秦九韶考中进士,先后担任县尉、通判、参议官、州守、同农、寺丞等职。先后在湖北、安徽、江苏、浙江等地做官,1261年左右被贬至梅州(今广东梅县),不久死于任所。他在政务之余,对数学进行虔心钻研,并广泛搜集历学、数学、星象、音律、营造等资料,进行分析、研究。宋淳祜四至七年(1244至1247),他在为母亲守孝时,把长期积累的数学知识和研究所得加以编辑,写成了闻名的巨著《数学九章》,并创造了“大衍求一术”。这不仅在当时处于世界领先地位,在近代数学和现代电子计算设计中,也起到了重要作用,被称为“中国剩余定理”。他所论的“正负开方术”,被称为“秦九韶程序”。现在,世界各国从小学、中学到大学的数学课程,几乎都接触到他的定理、定律和解题原则。秦九韶在数学方面的研究成果,比英国数学家取得的成果要早800多年。秦九韶字道古.普州安岳(今四川安岳)人.南宋嘉泰二年(1202年)生;约景定二年(1261年)卒于梅州(今广东梅县).
示标
1.学会用秦九韶算法求多项式的值。
高中数学1.3.2算法案例—秦九韶算法教案新人教A版必修
学 目
技能目标
模仿秦九韶计算方法,体会古人计算构思的巧妙;探究计算 机算法与数学算法的区别。
标
情感态度价值观
通过对秦九韶算法的学习,了解中国古代数学家对数学的贡 献,充分认识到我国文化历史的悠久。
重点 理解秦九韶算法的思想。
难点 用循环结构表示算法的步骤。
问题与情境及教师活动
学生活动
一.复习引入
大家都喜欢吃苹果吧,我们吃苹果都是从外到里一口一口的
(((an x an1)x an2 )x a1) a0
1 河北武邑教师教案
问题与情境及教师活动
学生活动
思考 2:对于由内向外逐层计算一次多项式
f (x) an xn an1xn1 a1x a0 (( an x an1)x an2 )x a1)x a0
的值,其算法步骤如何?
程序框图如下图:
2 河北武邑教师教案 问题与情境及教师活动
学生活动
INPUT “n=”;n
INPUT “an=”;a
INPUT “x=”;x
v=a
i=n-1
WHILE i>=0
PRINT “i=”;i
教
INPUT “ai=”;a
v=v*x+a
学
i=i-1
WEND
过
PRINT v
ENDห้องสมุดไป่ตู้
程 思考 3:该程序框图对应的程序如何表述?
第一步,输入多项式次数 n、最高次的系数 an 和 x 的值. 第二步,将 v 的值初始化为 an,将 i 的值初始化为 n-1. 第三步,输入 i 次项的系数 ai. 第四步,v=vx+ai,i=i-1. 第五步,判断 i 是否大于或等于 0.若是,则返回第三步;
(完整版)秦九韶算法公开课教案
1.3算法案例——秦九韶算法
授课年级
高一(117)班
授课类型
新授课
教
学
目
标
知识与技
能目标
了解秦九韶算法的计算过程,并理解利用秦九韶算法可以减少计算次数提高计算效率的实质。
过程与方
法目标
模仿秦九韶计算方法,体会古人计算构思的巧妙。了解数学计算转换为计算机计算的途径,从而探究计算机算法与数学算法的区别,体会计算机对数学学习的辅助作用。
乘法运算次数______,
加法运算次数______.
2.用秦九韶算法求多项式 当 时的值
多项式转化成了______个一次多项式,
乘法运算次数_________,
加法运算次数_________.
3.用循环结构表示秦九韶算法的关键步骤及程序框图
步骤:
(1)确定循环体:
(2)初始化变量:
(3)设定循环控制条件:
练习:画出当型循环结构。
引导学生认识秦九韶算法中的循环过程,并用算法的循环结构来表示这个过程。
(7)课堂小结
知识内容:秦九韶算法的特点及其程序设计
思想方法:算法思想,化归思想
使学生对知识有一个系统的认识,突出重点,抓住关键,培养概括能力。
(8)课堂检测
见附件
(9)作业布置:习题1.3 A组第2题,《课堂检测》附加题
算法案例——秦九韶算法学案
学习目标:
了解秦九韶算法的计算过程,并理解利用秦九韶算法可以减少计算次数提高计算效率的实质。
问题
方法与思路
1.求当 时多项式 的值.
方法一:
乘法运算次数______,
加法运算次数______.
方法二:
算法案例——秦九韶算法教学课件人教课标版实用教案
《算法事例——秦九韶算法》教课方案陈甦福州高级中学一、教课目的:知识与能力:()认识秦九韶算法的计算过程,并理解利用秦九韶算法能够减少计算次数提升计算效率的本质。
()理解数学算法与计算机算法的差别,理解计算机对数学的协助作用。
过程与方法:在学习中国古代数学算法事例的同时,进一步领会算法的特色。
感情与态度:学习中国古代数学中算法事例的同时,进一步领会算法的特色和中国古代数学对世界数学发展的贡献。
二、教课要点:秦九韶算法的特色及其程序设计,理解秦九韶算法的思想。
三、教课难点:()秦九韶算法的先进性理解及其程序设计;()用循环构造表示算法步骤。
四、教课基本流程设计算法,求详细多项式的值改良算法,提升运算效率介绍秦九韶算法,求一般多项式的值用循环构造表示秦九韶算法的要点步骤对秦九韶算法和算法自己的特色进行小结五、教课方法:“再创建”活动学习、小组合作学习六、教课过程(秦九韶计算多项式的方法)、创建问题情境①:设计求多项式f(x)=x4+x3+x2+x+1当x=5时的值的算法,并写出程序。
(设计企图:使学生在自己操作的过程中进一步认识问题自己及其算法)。
、“创始”思路、问题解决创建问题情境②:上述算法有何优、弊端?有没有更高效的算法?(激发学生研究,改良算法,提升计算效率的意识,合时启迪学生从多项式变形下手;并指出这类算法就是“秦九韶算法”)创建问题情境③:设计求多项式f(x)=a4x4+a3x3+a2x2+a1x+a0当x=5时的值的算法。
(设计企图:从系数的特别化到系数的一般化)创建问题情境④:若将x的值代入变形后的式子中,那么求值的计算过程是如何的?(指引学生发现规律,归纳总结,设计程序框图。
)、解后再“创”创建问题情境⑤:我们从例题的第二次做法中遇到启迪,研究到了更加高效的算法,那可否利用秦九韶算法解决一般多项式的求值问题?(鼓舞学生进一步研究拥有一般意义的算法。
)f(x)=a n x n+a n-1x n-1++a1x+a0当x=x0时的值?共做了多少次乘法运算,多少次加法运算?.讲堂练习:()利用程序求多项式f(x)=4+x3-2+x+1当x=2时的值()利用程序求多项式f(x)=x7+x6-5+4+x3-2+x+1,当x=2时的值。
高中数学1.3《算法案例---秦九韶算法》教案人教版必修3A
〔教案〕 1.3 算法案例――-秦九韶算法
教学目标:
(1)在学习中国古代数学中的算法案例的同时,进一步体会算法的特点。
(2)体会中国古代数学对世界数学发展的贡献。
教学重点和难点
(1)重点:理解秦九韶算法的思想。
(2)难点:用循环结构表示算法的步骤。
教学基本流程
(1)设计算法,求具体多项式的值
(2)改进算法,提高运算效率
(3)介绍秦九韶算法,求一般多项式的值
(4)用循环结构表示秦九韶算法的关键步骤
(5)对秦九韶算法和算法本身的特点进行小结
教学情景设计
一、新课引入
在数学的发展史上,从公元前2、3世纪公元14世纪,中国
的数学虽有过高潮,也有过低落,但一直走在世界的前列,是世界数学的中心。
中国古代数学对世界数学发展有着不可磨灭的贡献。
秦九韶算法就是中国古代数学的一枝奇葩。
今天这节课我们领略秦九韶算法的魅力。
二、问题设计。
1.3 案例2 秦九韶算法
((an x an1 ) x an 2 ) x a1 ) x a0
当知道了x的值后该如何求多项式的值?
f ( x ) ((an x an1 ) x an 2 ) x a1 ) x a0
要求多项式的值,应该先算最内层的一次多 项式的值,即
所以,当x = 2时,多项式的值等于-41.
高中数学备课组
练习: 已知多项式f(x)=x5+5x4+10x3+10x2+5x+1 用秦九韶算法求这个多项式当 x= -2 时的值.
f(-2)= -1.
高中数学备课组
秦九韶算法的程序框图:
开始 输入n, an, x的值 v=an
v 0 a n v k v k 1 x an k ( k 1,2, , n)
f (5)=55+54+53+52+5+1 =5×(54+53+52+5+1)+1
=5×(5×(53+52+5 +1)+1 )+1
=5×(5×( 5× (52+5 +1)+1 )+1 )+1
=5×(5×(5× (5 × (5 +1 ) +1 )+1 )+1 )+1
两种算法中各用了几次乘法运算? 几次加法运算?
f ( x ) an x n an1 x n1 a1 x a0 (an x n1 an1 x n 2 a1 ) x a0
(( an x n 2 an1 x n 3 a2 ) x a1 ) x a0
高中数学备课组
v1 an x an1
然后,由内到外逐层计算一次多项式的值,即
高中数学备课组
v 3 v 2 x an 3
v n v n 1 x a 0
《算法案例:秦九韶算法》教学教案
《算法案例:秦九韶算法》教学教案第一篇:《算法案例:秦九韶算法》教学教案秦九韶算法学习目标1.了解秦九韶算法的计算过程,并理解利用秦九韶算法可以减少计算次数提高计算效率的实质。
2.掌握数据排序的原理能使用直接排序法与冒泡排序法给一组数据排序,进而能设计冒泡排序法的程序框图及程序,理解数学算法与计算机算法的区别,理解计算机对数学的辅助作用。
学习重难点重点:1.秦九韶算法的特点2.两种排序法的排序步骤及计算机程序设计难点:1.秦九韶算法的先进性理解2.排序法的计算机程序设计学法与学习用具学法:1.探究秦九韶算法对比一般计算方法中计算次数的改变,体会科学的计算。
2.模仿排序法中数字排序的步骤,理解计算机计算的一般步骤,领会数学计算在计算机上实施的要求。
学习用具:电脑,计算器,图形计算器学习设想(一)创设情景,揭示课题我们已经学过了多项式的计算,下面我们计算一下多项式f(x)=x5+x4+x3+x2+x+1当x=5时的值,并统计所做的计算的种类及计算次数。
根据我们的计算统计可以得出我们共需要10次乘法运算,5次加法运算。
我们把多项式变形为:f(x)=x2(1+x(1+x(1+x)))+x+1再统计一下计算当x=5时的值时需要的计算次数,可以得出仅需4次乘法和5次加法运算即可得出结果。
显然少了6次乘法运算。
这种算法就叫秦九韶算法。
(二)研探新知/ 41.秦九韶计算多项式的方法f(x)=anxn+an-1xn-1+an-2xn-2+Λ+a1x+a0=(anxn-1+an-1xn-2+an-2xn-3+Λ+a1)x+a0=((anxn-2+an-1xn-3+Λ+a2)x+a1)x+a0=ΛΛ=(Λ((anx+an-1)x+an-2)x+Λ+a1)+a0例1 已知一个5次多项式为f(x)=5x5+2x4+3.5x3-2.6x2+1.7x-0.8 用秦九韶算法求这个多项式当x=5时的值。
解:略思考:(1)例1计算时需要多少次乘法计算?多少次加法计算?(2)在利用秦九韶算法计算n次多项式当x=x0时需要多少次乘法计算和多少次加法计算?练习:利用秦九韶算法计算f(x)=0.83x5+0.41x4+0.16x3+0.33x2+0.5x+1 当x=5时的值,并统计需要多少次乘法计算和多少次加法计算?例2 设计利用秦九韶算法计算5次多项式f(x)=a5x5+a4x4+a3x3+a2x2+a1x+a0当x=x0时的值的程序框图。
《算法案例秦九韶算法》教学教案
《算法案例秦九韶算法》教学教案教学目标:1.理解秦九韶算法的原理和应用场景;2.掌握秦九韶算法的详细步骤;3.能够实现秦九韶算法的代码;4.能够对秦九韶算法进行分析和优化。
教学重点:1.秦九韶算法的原理和应用场景;2.秦九韶算法的详细步骤;3.秦九韶算法代码的实现。
教学难点:1.秦九韶算法的详细步骤;2.秦九韶算法代码的实现。
教学准备:1.讲义资料;2.演示程序;3.物理实例。
教学过程:一、导入(5分钟)教师利用一个简单的问题引入,例如:求多项式的值f(x)=2x^3+3x^2-5x+1,当x=2时,计算f(x)。
二、提问(5分钟)教师提问学生在计算多项式的值时的一般方法是什么,学生回答:将x的值代入多项式中的每一项并相加。
三、引入秦九韶算法(10分钟)教师引入秦九韶算法,并解释该算法可以大大减少计算量和运算时间的原理。
教师给出一个示例多项式f(x)=2x^3+3x^2-5x+1,当x=2时,计算f(x),并演示传统的计算方法和秦九韶算法的计算方法的对比。
四、秦九韶算法的详细步骤(20分钟)教师逐步讲解秦九韶算法的详细步骤:1.将多项式表达式改写成累加表达式,例如:f(x)=((2x+3)x-5)x+1;2.从内层开始计算并求解,逐步向外推算;3.计算每一层的累加结果,并将结果保存在一个变量中。
五、练习(15分钟)教师提供多个多项式表达式和对应的x值,让学生尝试用秦九韶算法计算结果,并对结果进行验证。
六、算法优化(15分钟)教师指导学生对秦九韶算法进行分析和优化,例如:是否存在重复计算的部分,可以通过建立一个字典来记录已经计算过的结果,以便在后续计算中直接使用。
七、总结(10分钟)教师帮助学生总结秦九韶算法的优点和适用场景,并与传统计算方法进行对比。
教学延伸:将秦九韶算法应用到实际问题中,例如多项式插值、图像处理等,并引导学生进行深入的研究和讨论。
教学反思:在教学过程中,要注意对秦九韶算法的详细步骤进行清晰的讲解,引导学生理解其原理和应用场景。
新人教A版必修3高中数学学案教案: §1.3算法案例(秦九韶算法)教案
时案例2 秦九韶算法(一)导入新课思路1(情境导入)大家都喜欢吃苹果吧,我们吃苹果都是从外到里一口一口的吃,而虫子却是先钻到苹果里面从里到外一口一口的吃,由此看来处理同一个问题的方法多种多样.怎样求多项式f(x)=x5+x4+x3+x2+x+1当x=5时的值呢?方法也是多种多样的,今天我们开始学习秦九韶算法.思路2(直接导入)前面我们学习了辗转相除法与更相减损术,今天我们开始学习秦九韶算法.(二)推进新课、新知探究、提出问题(1)求多项式f(x)=x5+x4+x3+x2+x+1当x=5时的值有哪些方法?比较它们的特点.(2)什么是秦九韶算法?(3)怎样评价一个算法的好坏?讨论结果:(1)怎样求多项式f(x)=x5+x4+x3+x2+x+1当x=5时的值呢?一个自然的做法就是把5代入多项式f(x),计算各项的值,然后把它们加起来,这时,我们一共做了1+2+3+4=10次乘法运算,5次加法运算.另一种做法是先计算x2的值,然后依次计算x2·x,(x2·x)·x,((x2·x)·x)·x 的值,这样每次都可以利用上一次计算的结果,这时,我们一共做了4次乘法运算,5次加法运算.第二种做法与第一种做法相比,乘法的运算次数减少了,因而能够提高运算效率,对于计算机来说,做一次乘法运算所用的时间比做一次加法运算要长得多,所以采用第二种做法,计算机能更快地得到结果.(2)上面问题有没有更有效的算法呢?我国南宋时期的数学家秦九韶(约1202~1261)在他的著作《数书九章》中提出了下面的算法:把一个n次多项式f(x)=a n x n+a n-1x n-1+…+a1x+a0改写成如下形式:f(x)=a n x n+a n-1x n-1+…+a1x+a0=(a n x n-1+a n-1x n-2+…+a1)x+ a0=((a n x n-2+a n-1x n-3+…+a2)x+a1)x+a0=…=(…((a n x+a n-1)x+a n-2)x+…+a1)x+a0.求多项式的值时,首先计算最内层括号内一次多项式的值,即v1=a n x+a n-1,然后由内向外逐层计算一次多项式的值,即v2=v1x+a n-2,v3=v2x+a n-3,…v n=v n-1x+a0,这样,求n次多项式f(x)的值就转化为求n个一次多项式的值.上述方法称为秦九韶算法.直到今天,这种算法仍是多项式求值比较先进的算法.(3)计算机的一个很重要的特点就是运算速度快,但即便如此,算法好坏的一个重要标志仍然是运算的次数.如果一个算法从理论上需要超出计算机允许范围内的运算次数,那么这样的算法就只能是一个理论的算法.(三)应用示例例1 已知一个5次多项式为f (x )=5x 5+2x 4+3.5x 3-2.6x 2+1.7x-0.8,用秦九韶算法求这个多项式当x=5时的值.解:根据秦九韶算法,把多项式改写成如下形式:f(x)=((((5x+2)x+3.5)x-2.6)x+1.7)x-0.8,按照从内到外的顺序,依次计算一次多项式当x=5时的值:v 0=5;v 1=5×5+2=27;v 2=27×5+3.5=138.5;v 3=138.5×5-2.6=689.9;v 4=689.9×5+1.7=3 451.2;v 5=3 415.2×5-0.8=17 255.2;所以,当x=5时,多项式的值等于17 255.2.算法分析:观察上述秦九韶算法中的n 个一次式,可见v k 的计算要用到v k -1的值,若令v 0=a n ,我们可以得到下面的公式:⎩⎨⎧=+==--).,,2,1(,10n k a x v v a v k n k kn Λ 这是一个在秦九韶算法中反复执行的步骤,因此可用循环结构来实现.算法步骤如下:第一步,输入多项式次数n 、最高次的系数a n 和x 的值.第二步,将v 的值初始化为a n ,将i 的值初始化为n-1.第三步,输入i 次项的系数a i .第四步,v=vx+a i ,i=i-1.第五步,判断i 是否大于或等于0.若是,则返回第三步;否则,输出多项式的值v. 程序框图如下图:程序:INPUT “n=”;nINPUT “an=”;aINPUT “x=”;xv=ai=n-1WHILE i>=0PRINT “i=”;iINPUT “ai=”;av=v*x+ai=i-1WENDPRINT vEND点评:本题是古老算法与现代计算机语言的完美结合,详尽介绍了思想方法、算法步骤、程序框图和算法语句,是一个典型的算法案例.变式训练请以5次多项式函数为例说明秦九韶算法,并画出程序框图.解:设f(x)=a5x5+a4x4+a3x3+a2x2+a1x+a0首先,让我们以5次多项式一步步地进行改写:f(x)=(a5x4+a4x3+a3x2+a2x+a1)x+a0=((a5x3+a4x2+ a3x+a2)x+a1)x+a0=(((a5x2+a4x+ a3)x+a2)x+a1)x+a0=((((a5x+a4)x+ a3)x+a2)x+a1)x+a0.上面的分层计算,只用了小括号,计算时,首先计算最内层的括号,然后由里向外逐层计算,直到最外层的括号,然后加上常数项即可.程序框图如下图:例2 已知n次多项式P n(x)=a0x n+a1x n-1+…+a n-1x+a n,如果在一种算法中,计算k x0(k=2,3,4,…,n)的值需要k-1次乘法,计算P3(x0)的值共需要9次运算(6次乘法,3次加法),那么计算P10(x0)的值共需要__________次运算.下面给出一种减少运算次数的算法:P0(x)=a0,P k+1(x)=xP k(x)+a k+1(k=0,1,2,…,n-1).利用该算法,计算P3(x0)的值共需要6次运算,计算P10(x0)的值共需要___________次运算.答案:65 20点评:秦九韶算法适用一般的多项式f(x)=a n x n+a n-1x n-1+…+a1x+a0的求值问题.直接法乘法运算的次数最多可到达2)1(nn,加法最多n次.秦九韶算法通过转化把乘法运算的次数减少到最多n次,加法最多n次.例3 已知多项式函数f(x)=2x5-5x4-4x3+3x2-6x+7,求当x=5时的函数的值.解析:把多项式变形为:f(x)=2x5-5x4-4x3+3x2-6x+7=((((2x-5)x-4)x+3)x-6)x+7.计算的过程可以列表表示为:最后的系数2 677即为所求的值.算法过程:v0=2;v1=2×5-5=5;v2=5×5-4=21;v3=21×5+3=108;v4=108×5-6=534;v5=534×5+7=2 677.点评:如果多项式函数中有缺项的话,要以系数为0的项补齐后再计算.(四)知能训练当x=2时,用秦九韶算法求多项式f(x)=3x5+8x4-3x3+5x2+12x-6的值.解法一:根据秦九韶算法,把多项式改写成如下形式:f(x)=((((3x+8)x-3)x+5)x+12)x-6.按照从内到外的顺序,依次计算一次多项式当x=2时的值.v0=3;v1=v0×2+8=3×2+8=14;v2=v1×2-3=14×2-3=25;v3=v2×2+5=25×2+5=55;v4=v3×2+12=55×2+12=122;v5=v4×2-6=122×2-6=238.∴当x=2时,多项式的值为238.解法二:f(x)=((((3x+8)x-3)x+5)x+12)x-6,则f(2)=((((3×2+8)×2-3)×2+5)×2+12)×2-6=238.(五)拓展提升用秦九韶算法求多项式f(x)=7x7+6x6+5x5+4x4+3x3+2x2+x当x=3时的值.解:f(x)=((((((7x+6)+5)x+4)x+3)x+2)x+1)xv0=7;v1=7×3+6=27;v2=27×3+5=86;v3=86×3+4=262;v4=262×3+3=789;v5=789×3+2=2 369;v6=2 369×3+1=7 108;v7=7 108×3+0=21 324.∴f(3)=21 324.(六)课堂小结1.秦九韶算法的方法和步骤.2.秦九韶算法的计算机程序框图.(七)作业已知函数f(x)=x3-2x2-5x+8,求f(9)的值.解:f(x)=x3-2x2-5x+8=(x2-2x-5)x+8=((x-2)x-5)x+8 ∴f(9)=((9-2)×9-5)×9+8=530.。
(完整版)算法案例教案
课题:§1.3算法案例第1课时辗转相除法与更相减损术、秦九韶算法一、教学目标:根据课标要求:在学生学习了算法的初步知识,理解了表示算法的算法步骤、程序框图和程序三种不同方式以后,再结合典型算法案例,让学生经历设计算法解决问题的全过程,体验算法在解决问题中的重要作用,体会算法的基本思想,提高逻辑思维能力,发展有条理地思考与数学表达能力。
制定以下三维目标:1、知识与技能理解算法案例的算法步骤和程序框图.2、过程与方法:引导学生得出自己设计的算法程序.3、情感态度与价值观:体会算法的基本思想,提高逻辑思维能力,发展有条理地思考与数学表达能力.二、重点与难点:重点:引导学生得出自己设计的算法步骤、程序框图和算法程序.解决策略:通过分析解决具体问题的算法步骤来引导学生写出算法,根据算法画出程序框图,再根据框图用规范的语言写出程序。
难点:体会算法的基本思想,提高逻辑思维能力,发展有条理地思考与数学表达能力.解决策略:让学生能严谨地按照自己是程序框图写出程序。
三、学法与教学用具:1、学法:直观感知、操作确认。
2、教学用具:多媒体。
四、教学过程(一)引入课题大家喜欢打乒乓球吧,由于东、西方文化及身体条件的不同,西方人喜欢横握拍打球,东方人喜欢直握拍打球,对于同一个问题,东、西方人处理问题方式是有所不同的.在小学,我们学过求两个正整数的最大公约数的方法:先用两个数公有的质因数连续去除,一直除到所得的商是互质数为止,然后把所有的除数连乘起来. 当两个数公有的质因数较大时(如8 251与6 105),使用上述方法求最大公约数就比较困难.下面我们介绍两种不同的算法——辗转相除法与更相减损术,由此可以体会东、西方文化的差异.(二)研探新知(1)怎样用短除法求最大公约数?(2)怎样用穷举法(也叫枚举法)求最大公约数?(3)怎样用辗转相除法求最大公约数?(4)怎样用更相减损术求最大公约数?讨论结果:(1)短除法求两个正整数的最大公约数的步骤:先用两个数公有的质因数连续去除,一直除到所得的商是两个互质数为止,然后把所有的除数连乘起来.(2)穷举法(也叫枚举法)穷举法求两个正整数的最大公约数的解题步骤:从两个数中较小数开始由大到小列举,直到找到公约数立即中断列举,得到的公约数便是最大公约数.(3)辗转相除法辗转相除法求两个数的最大公约数,其算法步骤可以描述如下:第一步,给定两个正整数m,n.第二步,求余数r:计算m除以n,将所得余数存放到变量r中.第三步,更新被除数和余数:m=n,n=r.第四步,判断余数r是否为0.若余数为0,则输出结果;否则转向第二步继续循环执行. 如此循环,直到得到结果为止. 这种算法是由欧几里得在公元前300年左右首先提出的,因而又叫欧几里得算法.(4)更相减损术我国早期也有解决求最大公约数问题的算法,就是更相减损术. 《九章算术》是中国古代的数学专著,其中的“更相减损术”也可以用来求两个数的最大公约数,即“可半者半之,不可半者,副置分母、子之数,以少减多,更相减损,求其等也.以等数约之.”翻译为现代语言如下:第一步,任意给定两个正整数,判断它们是否都是偶数,若是,用2约简;若不是,执行第二步,以较大的数减去较小的数,接着把所得的差与较小的数比较,并以大数减小数,继续这个操作,直到所得的数相等为止,则这个数(等数)或这个数与约简的数的乘积就是所求的最大公约数.(三)范例分析例1 用辗转相除法求8 251与6 105的最大公约数,写出算法分析,画出程序框图,写出算法程序.解:用两数中较大的数除以较小的数,求得商和余数:8 251=6 105×1+2 146.由此可得,6 105与2 146的公约数也是8 251与6 105的公约数,反过来,8 251与6 105的公约数也是6 105与2 146的公约数,所以它们的最大公约数相等.对6 105与2 146重复上述步骤:6 105=2 146×2+1 813.同理,2 146与1 813的最大公约数也是6 105与2 146的最大公约数.继续重复上述步骤:2 146=1 813×1+333,1 813=333×5+148,333=148×2+37,148=37×4.最后的除数37是148和37的最大公约数,也就是8 251与6 105的最大公约数.这就是辗转相除法.由除法的性质可以知道,对于任意两个正整数,上述除法步骤总可以在有限步之后完成,从而总可以用辗转相除法求出两个正整数的最大公约数.算法分析:从上面的例子可以看出,辗转相除法中包含重复操作的步骤,因此可以用循环结构来构造算法.算法步骤如下:第一步,给定两个正整数m,n.第二步,计算m除以n所得的余数为r.第三步,m=n,n=r.第四步,若r=0,则m,n的最大公约数等于m;否则,返回第二步.程序框图如右图:程序:INPUT m,nDOr=m MOD nm=nn=rLOOP UNTIL r=0PRINT mEND例2 用更相减损术求98与63的最大公约数.解:由于63不是偶数,把98和63以大数减小数,并辗转相减,如下图所示.98-63=3563-35=2835-28=728-7=2121-7=1414-7=7所以,98和63的最大公约数等于7.前面我们学习了辗转相除法与更相减损术,现在我们来学习一种新的算法:秦九韶算法. (1)怎样求多项式f(x)=x5+x4+x3+x2+x+1当x=5时的值呢?一个自然的做法就是把5代入多项式f(x),计算各项的值,然后把它们加起来,这时,我们一共做了1+2+3+4=10次乘法运算,5次加法运算.另一种做法是先计算x2的值,然后依次计算x2·x,(x2·x)·x,((x2·x)·x)·x的值,这样每次都可以利用上一次计算的结果,这时,我们一共做了4次乘法运算,5次加法运算.第二种做法与第一种做法相比,乘法的运算次数减少了,因而能够提高运算效率,对于计算机来说,做一次乘法运算所用的时间比做一次加法运算要长得多,所以采用第二种做法,计算机能更快地得到结果.(2)上面问题有没有更有效的算法呢?我国南宋时期的数学家秦九韶(约1202~1261)在他的著作《数书九章》中提出了下面的算法:把一个n次多项式f(x)=a n x n+a n-1x n-1+…+a1x+a0改写成如下形式:f(x)=a n x n+a n-1x n-1+…+a1x+a0=(a n x n-1+a n-1x n-2+…+a1)x+ a0=((a n x n-2+a n-1x n-3+…+a2)x+a1)x+a0=…=(…((a n x+a n-1)x+a n-2)x+…+a1)x+a0.求多项式的值时,首先计算最内层括号内一次多项式的值,即v1=a n x+a n-1,然后由内向外逐层计算一次多项式的值,即v2=v1x+a n-2,v3=v2x+a n-3,…v n=v n-1x+a0,这样,求n 次多项式f (x )的值就转化为求n 个一次多项式的值.上述方法称为秦九韶算法.直到今天,这种算法仍是多项式求值比较先进的算法.(3)计算机的一个很重要的特点就是运算速度快,但即便如此,算法好坏的一个重要标志仍然是运算的次数.如果一个算法从理论上需要超出计算机允许范围内的运算次数,那么这样的算法就只能是一个理论的算法.例3 已知一个5次多项式为f (x )=5x 5+2x 4+3.5x 3-2.6x 2+1.7x-0.8,用秦九韶算法求这个多项式当x=5时的值.解:根据秦九韶算法,把多项式改写成如下形式:f(x)=((((5x+2)x+3.5)x-2.6)x+1.7)x-0.8,按照从内到外的顺序,依次计算一次多项式当x=5时的值:v 0=5;v 1=5×5+2=27;v 2=27×5+3.5=138.5;v 3=138.5×5-2.6=689.9;v 4=689.9×5+1.7=3 451.2;v 5=3 415.2×5-0.8=17 255.2;所以,当x=5时,多项式的值等于17 255.2.算法分析:观察上述秦九韶算法中的n 个一次式,可见v k 的计算要用到v k-1的值,若令v 0=a n ,我们可以得到下面的公式: ⎩⎨⎧=+==--).,,2,1(,10n k a x v v a v k n k kn Λ 这是一个在秦九韶算法中反复执行的步骤,因此可用循环结构来实现.算法步骤如下:第一步,输入多项式次数n 、最高次的系数a n 和x 的值.第二步,将v 的值初始化为a n ,将i 的值初始化为n-1.第三步,输入i 次项的系数a i .第四步,v=vx+a i ,i=i-1.第五步,判断i 是否大于或等于0.若是,则返回第三步;否则,输出多项式的值v.程序框图如右图:程序:INPUT “n=”;nINPUT “an=”;aINPUT “x=”;xv=ai=n-1WHILE i>=0PRINT “i=”;iINPUT “ai=”;av=v*x+ai=i-1WENDPRINT vEND(四)随堂练习P45练习 1、2(五)归纳总结(1)用辗转相除法求最大公约数.(2)用更相减损术求最大公约数.(3).秦九韶算法的方法和步骤.以及计算机程序框图.(六)作业布置1、P48 习题1.3 A组1、22、完成课后巩固作业(八)五、教学反思:_________________________________________________________ _________________________________________________________ _________________________________________________________ _________________________________________________________ _________________________________________________________1.3 算法案例第2课时进位制一、教学目标:根据课标要求:掌握不同进制之间的相互转化,会用程序描述不同进制之间的转化,体会数学的转化思想,制定以下三维目标:1、知识与技能学生理解各种进位制与十进制之间转换的规律,会利用十进制与各种进制之间的联系进行各种进位制之间的转换。
人教版高中数学必修3第一章算法初步-《1.3算法案例:秦九韶算法》教案
1.3算法案例:秦九韶算法1、利用秦九韶算法求多项式1153723+-+x x x 在23=x 的值时,在运算中下列哪个值用不到( )A 、164B 、3767C 、86652D 、851692、利用秦九韶算法计算多项式1876543x f(x)23456++++++x x x x x = 当x=4的值的时候,需要做乘法和加法的次数分别为( )A 、6,6B 、5,6C 、5,5D 、6,53、利用秦九韶算法求多项式1352.75.38123)(23456-++-++=x x x x x x x f 在6=x 的值,写出详细步骤。
4、下图的框图是一古代数学家的一个算法的程序框图,它输出的 结果s 表示( )A 、3210a a a a +++的值B 、300201032x a x a x a a +++的值 C 、303202010x a x a x a a +++的值 D 、以上都不对5、已知n 次多项式1011()n n n n n P x a x a x a x a --=++++,如果在一种算法中,计算0k x (k =2,3,4,…,n )的值需要k -1次乘法,(1)计算30()P x 的值需要9次运算(6次乘法,3次加法),那么计算0()n P x 的值需要多少次运算?(2)若采取秦九韶算法:0011(),()()k k k P x a P x xP x a ++==+(k =0, 1,2,…,n -1),计算30()P x 的值只需6次运算,那么计算0()n P x 的值共需要多少次运算?(3)若采取秦九韶算法,设a i =i+1,i=0,1,…,n ,求P 5(2)(写出采取秦九韶算法的计算过程)答案:1、D2、A3、解:13)5)2.7)5.3)8)123((((()(-++-++=x x x x x x x f2.243168)6(2.2431681362.40530562.67542.765.11245.36188863012635645342312010==-⨯==+⨯==+⨯==-⨯==+⨯==+⨯==f v v v v v v v v v v v v v4、C5、n +3)(2)2n ;(3)∵0011(),()()k k k P x a P x xP x a ++==+,∴P0(2)=1,P1(2)=2P0(2)+2=4;P2(2)=2P1(2)+3=11;P3(2)=2P2(2)+4=26;P4(2)=2P3(2)+5=57;P5(2)=2P4(2)+6=120。
算法案例---秦九韶算法
+
变形后 x 的系数
4
22 113.5 564.9 2826.2 14130.2 *5
思考:让学生回顾整个计算过程,用此种方法一共进行了多少次乘法、加法运算? 点评:一共进行了 5 次乘法,5 次加法运算,相比较前两种做法,此做法更快、更方便,而 且在计算过程中,只与多项式的系数有关。 这种算法就是“秦九韶算法”,在此可以介绍下秦九韶生平。【见附页】 (二)研探新知
数学四大家。其父秦季栖,进士出身,官至上部郎中、秘书少监。
秦九韶聪敏勤学。
宋绍定四年(1231),秦九韶考中进士,先后担任县尉、通判、参议官、州守、同农、寺丞
等职。先后在湖北、安徽、江苏、浙江等地做官,1261 年左右被贬至梅州(今广东梅县),
不久死于任所。他在政务之余,对数学进行虔心钻研,并广泛搜集历学、数学、星象、音律、
秦九韶所发明的“大衍求一术”,即现代数论中一次同余式组解法,是中世纪世界数学 的最高成就,比西方 1801 年著名数学家高斯(Gauss,1777―1855 年)建立的同余理论早 554 年,被西方称为“中国剩余定理”。秦九韶不仅为中国赢得无尚荣誉,也为世界数学作 出了杰出贡献。 3、秦九韶的任意次方程的数值解领先霍纳 572 年
问题 1:怎样用秦九韶算法求一般的多项式 f (x) an x n an1x n1 a1x a0 当
x=x0 时的值? 类似上述方法,将多项式变形为:
f (x) an x n an1x n1 an2 x n2 a1x a0 (an x n1 an1 x n2 an2 x n3 a1 )x a0 ((an x n2 an1x n3 a2 )x a1 )x a0 (((an x an1 )x an2 )x a1 ) a0
1.3(1) 辗转相除法与更相减损术、秦九韶算法)(教学设计)
1.3(1)辗转相除法和更相减损术、秦九韶算法(教学设计)一、教学目标:1、知识与技能⑴理解辗转相除法与更相减损术中蕴含的数学原理,并能根据这些原理进行算法分析;⑵基本能根据算法语句与程序框图的知识设计完整的程序框图并写出算法程序.(3)了解秦九韶算法的计算过程,并理解利用秦九韶算法可以减少计算次数提高计算效率的实质;(4)基本能根据算法语句与程序框图的知识设计完整的程序框图并写出算法程序.2、过程与方法在辗转相除法与更相减损术求最大公约数的学习过程中对比我们常见的约分求公因式的方法,比较它们在算法上的区别,并从程序的学习中体会数学的严谨,领会数学算法与计算机处理的结合方式,初步掌握把数学算法转化成计算机语言的一般步骤.模仿秦九韶计算方法,体会古人计算构思的巧妙. 并从程序的学习中体会数学的严谨,领会数学算法与计算机处理的结合方式,初步掌握把数学算法转化成计算机语言的一般步骤.3、情感与价值观⑴通过阅读中国古代数学中的算法案例,体会中国古代数学对世界数学发展的贡献.⑵在学习古代数学家解决数学问题的方法的过程中培养严谨的逻辑思维能力,在利用算法解决数学问题的过程中培养理性的精神和动手实践的能力.二、教学重点、难点:重点:理解辗转相除法与更相减损术求最大公约数的方法.难点:把辗转相除法与更相减损术的方法转换成程序框图与程序语言.三、教学过程:(一)创设情景、导入课题1.研究一个实际问题的算法,主要从哪几方面展开?算法步骤、程序框图和编写程序三方面展开.2.在程序框图中算法的基本逻辑结构有哪几种?顺序结构、条件结构、循环结构3.在程序设计中基本的算法语句有哪几种?输入语句、输出语句、赋值语句、条件语句、循环语句4.思考1:18与30的最大公约数是多少?你是怎样得到的?5. 思考2:对于8251与6105这两个数,它们的最大公约数是多少?你是怎样得到的?由于它们公有的质因数较大,利用上述方法求最大公约数就比较困难.有没有其它的方法可以较简单的找出它们的最大公约数呢?(板书课题)(二)师生互动、探究新知1. 辗转相除法思考3:注意到8251=6105×1+2146,那么8251与6105这两个数的公约数和6105与2146的公约数有什么关系? 我们发现6105=2146×2+1813,同理,6105与2146的公约数和2146与1813的公约数相等. 思考4:重复上述操作,你能得到8251与6105这两个数的最大公约数吗? 6105=2146×2+1813 2146=1813×1+333 1813=333×5+148 333=148×2+37 148=37×4+0以上我们求最大公约数的方法就是辗转相除法,也叫欧几里德算法,它是由欧几里德在公元前300年左右首先提出的.利用辗转相除法求最大公约数的步骤如下:第一步:用较大的数m 除以较小的数n 得到一个商0q 和一个余数0r ;第二步:若0r =0,则n 为m ,n 的最大公约数;若0r ≠0,则用除数n 除以余数0r 得到一个商1q 和一个余数1r ; 第三步:若1r =0,则0r 为m ,n 的最大公约数;若1r ≠0,则用除数0r 除以余数1r 得到一个商2q 和一个余数2r ; ……依次计算直至n r =0,此时所得到的1 n r 即为所求的最大公约数. 思考5:你能把辗转相除法编成一个计算机程序吗? 第一步,给定两个正整数m ,n(m>n). 第二步,计算m 除以n 所得的余数r. 第三步,m=n ,n=r.第四步,若r=0,则m ,n 的最大公约数等于m ;否则,返回第二步.INPUT m ,nDOr=m MOD n m=n n=rLOOP UNTIL r=0 PRINT m END思考6:如果用当型循环结构构造算法,则用辗转相除法求两个正整数m,n的最大公约数的程序框图和程序分别如何表示?INPUT m,nWHILE n>0r=m MOD nm=nn=rWENDPRINT mEND例1:用辗转相除法求225与135的最大公约数?略:45是90和45的最大公约数,也就是225和135的最大公约数2.更相减损术《九章算术》是中国古代的数学专著,其中的“更相减损术”也可以用来求两个数的最大公约数更相减损术求最大公约数的步骤如下:“可半者半之,不可半者,副置分母、子之数,以少减多,更相减损,求其等也,以等数约之.”翻译出来为:第一步:任意给出两个正整数;判断它们是否都是偶数. 若是,用2约简;若不是,执行第二步.第二步:以较大的数减去较小的数,接着把较小的数与所得的差比较,并以大数减小数。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
1.3算法案例(二)__秦九韶算法
一、内容及其解析
本节的教学内容是算法案例中的秦九韶算法,它是求一元多项式的值的一种方法.在初中,学生已经学习了多项式的有关知识,那里是把多项式看作代数式.因此在本段内容的教学之前,应当先向学生说明,这里是函数的观点考察多项式,因此,求自变量取某个实数时的函数值问题,即求多项式的值就是一个常规问题.
二、教学目标及其解析
目标定位
知识与技能:了解秦九韶算法的计算过程,并理解利用秦九韶算法可以减少计算次数提高计算效率的实质.
过程与方法:模仿秦九韶计算方法,体会古人计算构思的巧妙.了解数学计算转换为计算机计算的途径,从而探究计算机算法与数学算法的区别,体会计算机对数学学习的辅助作用.情感态度与价值观目标:通过对秦九韶算法的学习,了解中国古代数学对世界数学发展的贡献,充分认识到我国文化历史的悠久.
目标解析
1 秦九韶算法是我国南宋数学家秦九韶在他的代表作《数书九章》中提出的一种用于计算一元n 次多项式的值的方法.
三、问题诊断分析
在本节主要存在的问题是学生不能对秦九韶算法的先进性及其程序设计的理解,所以教师要强调当多项式的次数增大时,此种方法的先进性就体现出来了,所以教师要找到规律,让学生体会此种解法的先进性.
四、教学支持条件分析的一般模式
在本节课的教学中准备使用多媒体辅助教学.
五、教学过程设计
问题一 什么事了解秦九韶算法?
小问题1 怎样求多项式1)(2
345+++++=x x x x x x f 当x=5时的值呢?
(设计意图:通过具体的例子引入秦九韶算法.)
结论:第一种一共用了10次乘法运算,5次加法运算.而第二种一共用了5次乘法运算,5次加法运算.
小问题2 用秦九韶算法求n 次多项式0111...)(a x a x a x a x f n n n n ++++=--当0x x =(0
x 是任意实数)时的值,需要多少次乘法运算,多少次加法运算?
小问题 3 如何用秦九韶算法完成一般多项式
1110()n n n n f x a x a x a x a --=++++的求值
问题?
要求多项式的值,我们可以把它改写成:11101210()(()))n n n n n n n f x a x a x a x a a x a x a x a x a ----=++++=+++++.
首先计算最内层括号内一次多项式的值,即
11n n v a x a -=+,然后由内向外逐层计算一次多项式的值,即212n v v x a -=+,323n v v x a -=+,,10
n n v v x a -=+.
例题1 (课本第38页例2)(设计意图:从实例到一般,先总结实例进而引申到一般) 变式巩固 用秦九韶算法求多项式1432)(2367+-+-=x x x x x f 当x=2时的函数值.
小问题4 你是怎么理解秦九韶算法的?
结论:秦九韶算法将求n 次多项式的值转化为求n 个一次多项式的值.
课堂小结(提问方式)
秦九韶算法计算多项式的值及程序设计
上述的整个过程只需n 次乘法运算和n 次加法运算;观察上述n 个一次式,可发出k v 的计算要用到1k v -的值,若令0n v a =,可得到下列递推公式:01,(1,2,,)n k k n k v a v v x a k n --=⎧⎨=+=⎩. 这是一个反复执行的步骤,因此可用循环结构来实现.
【程序框图】:
六 目标检测
1、利用秦九韶算法求多项式1153723+-+x x x 在23=x 的值时,在运算中下列哪个值用不到( )
A 、164
B 、3767
C 、86652
D 、85169
2、利用秦九韶算法求多项式1352.75.38123)(23456-++-++=x x x x x x x f 在2=x 的值,写出详细步骤.
七 配餐作业
A 组
②秦九韶算法计算多项式f(x)=12+35x-8x 2+79x 3+6x 4+5x 5+3x 6
,当x=-4时的值时,υ3的值为( )
A .-845
B .220
C .-57
D .34
③用秦九韶算法,求当x=2时,f(x)=x 5-5x 4+x 3-1的函数值.
B 组
1.秦九韶算法与直接计算相比较,下列说法错误的是( )
A 、秦九韶算法与直接计算相比较,大大减少了乘法的次数,使计算量减少,并且逻辑结构简单.
B 、秦九韶算法减少了做乘法的次数,在计算机上也就加快了计算的速度.
C 、秦九韶算法减少了做乘法的次数,在计算机上也就降低了计算的速度.
D 、秦九韶算法避免对自变量x 单独做幂的计算,而是与系数一起逐次增长幂次,从而可提高计算的精度.
2.用秦九韶算法和直接算法求当0x x =时
()654323126016024019264f x x x x x x x =-+-+-+的值,做的乘法次数分别为( )
A.6,20
B.7,20
C.7,21
D.6,21
C 组
求15.033.016.041.083.0)(2
345+++++=x x x x x x f 当x=5时的值.
八、教学反思
1、学生还是不会分析运算次数的问题,应该给学生详细讲解.
2、学生在多项式 11101210()(()))n n n n n n n f x a x a x a x a a x a x a x a x a ----=++++=+++++
按照秦九韶算法写成标准形式是容易出错,且速度很慢,应教会学生快速的写法及检验方法.
3、应多给学生介绍一些有关秦九韶算法的背景知识,这样更能吸引学生的注意力和学习兴趣,另外介绍历史名人的大致成就,扩大学生的文化视野.。