高中数学必修三知识讲解,巩固练习(复习补习,期末复习资料):05【基础】算法案例

文档属性

名称 高中数学必修三知识讲解,巩固练习(复习补习,期末复习资料):05【基础】算法案例
格式 zip
文件大小 164.5KB
资源类型 教案
版本资源 人教新课标A版
科目 数学
更新时间 2019-07-18 10:58:44

图片预览

文档简介

算法案例
【学习目标】
1.理解辗转相除法与更相减损术中蕴含的数学原理,并能根据这些原理进行算法分析;
2.基本能根据算法语句与程序框图的知识设计完整的程序框图并写出算法程序;
3.了解秦九韶算法的计算过程,并理解利用秦九韶算法可以减少计算次数提高计算效率的实质;
4.了解各种进位制与十进制之间转换的规律,会利用各种进位制与十进制之间的联系进行各种进位制之间的转换.
【要点梳理】
要点一、辗转相除法
也叫欧几里德算法,它是由欧几里德在公元前300年左右首先提出的.利用辗转相除法求最大公约数的步骤如下:
第一步:用较大的数m除以较小的数n得到一个商q0和一个余数r0;
第二步:若r0=0,则n为m,n的最大公约数;若r0≠0,则用除数n除以余数r0得到一个商q1和一个余数r1;
第三步:若r1=0,则r0为m,n的最大公约数;若r1≠0,则用除数r0除以余数r1得到一个商q2和一个余数r2;
……
依次计算直至rn=0,此时所得到的rn-1即为所求的最大公约数.
用辗转相除法求最大公约数的程序框图为:
/
程序:
INPUT “m=”;m
INPUT “n=”;n
IF mx=m
m=n
n=x
END IF
r=m MOD n
WHILE r<>0
r=m MOD n
m=n
n=r
WEND
PRINT n
END
要点诠释:
辗转相除法的基本步骤是用较大的数除以较小的数,考虑到算法中的赋值语句可以对同一变量多次赋值,我们可以把较大的数用变量m表示,把较小的数用变量n表示,这样式子就是一个反复执行的步骤,因此可以用循环结构实现算法.
要点二、更相减损术
我国早期也有解决求最大公约数问题的算法,就是更相减损术.
更相减损术求最大公约数的步骤如下:可半者半之,不可半者,副置分母、子之数,以少减多,更相减损,求其等也.以等数约之.
翻译出来为:
第一步:任意给出两个正整数;判断它们是否都是偶数.若是,用2约简;若不是,执行第二步.
第二步:以较大的数减去较小的数,接着把较小的数与所得的差比较,并以大数减小数.继续这个操作,直到所得的数相等为止,则这个数(等数)就是所求的最大公约数.
理论依据:
由,得与有相同的公约数
更相减损术一般算法:
第一步,输入两个正整数;
第二步,如果,则执行,否则转到;
第三步,将的值赋予;
第四步,若,则把赋予,把赋予,否则把赋予,重新执行;
第五步,输出最大公约数.
程序:
INPUT “a=”,a
INPUT “b=”,b
WHILE a<>b
IF a>=b
a=a-b;
ELSE
b=b-a
WEND
END
PRINT b
或者
INPUT “请输入两个不相等的正整数”;a,b
i=0
WHILE a MOD 2=0 AND b MOD 2=0
a=a/2
b=b/2
i=i+1
WEND
DO
IF bt=a
a=b
b=t
END IF
c=a-b
a=b
b=c
LOOP UNTIL a=b
PRINT a^i
END
要点诠释:
用辗转相除法步骤较少,而更相减损术虽然有些步骤较长,但运算简单.
要点三、秦九韶计算多项式的方法
令,则有,其中.这样,我们便可由依次求出;
要点诠释:
显然,用秦九韶算法求n次多项式的值时只需要做n次乘法和n次加法运算
要点四、进位制
进位制是一种记数方式,用有限的数字在不同的位置表示不同的数值.可使用数字符号的个数称为基数,基数为n,即可称n进位制,简称n进制.现在最常用的是十进制,通常使用10个阿拉伯数字0-9进行记数.
对于任何一个数,我们可以用不同的进位制来表示.比如:十进数57,可以用二进制表示为111001,也可以用八进制表示为71、用十六进制表示为39,它们所代表的数值都是一样的.
表示各种进位制数一般在数字右下角加注来表示,如111001(2)表示二进制数,34(5)表示5进制数.
1.k进制转换为十进制的方法:
,把k进制数a转化为十进制数b的算法程序为:
INPUT “ a,k,n=”;a,k,n
i=1
b=0
WHILE i<=n
t=GET a[i]
b=b+t*k^(i-1)
i=i+1
WEND
PRINT b
END
2.十进制转化为k进制数b的步骤为:
第一步,将给定的十进制整数除以基数k,余数便是等值的k进制的最低位;
第二步,将上一步的商再除以基数k,余数便是等值的k进制数的次低位;
第三步,重复第二步,直到最后所得的商等于0为止,各次所得的余数,便是k进制各位的数,最后一次余数是最高位,即除k取余法.
要点诠释:
1、在k进制中,具有k个数字符号.如二进制有0,1两个数字.
2、在k进制中,由低位向高位是按“逢k进一”的规则进行计数.
3、非k进制数之间的转化一般应先转化成十进制,再将这个十进制数转化为另一种进制的数,有的也可以相互转化.
【典型例题】
类型一:辗转相除法与更相减损术
例1.用辗转相除法求下列两数的最大公约数,并且用更相减损术检验你的结果:
(1)80,36;(2)294,84.
【答案】(1)4(2)42
【解析】(1)80=36×2+8,
36=8×4+4.
8=4×2+0.
即80与36的最大公约数是4.
验证:80-36=44,
44-36=8.
36-8=28.
28-8=20.
20-8=12.
12-8=4.
8-4=4.
∴80与36的最大公约数为4.
(2)294=84×3+42,
84=42×2.
即294与84的最大公约数是42.
验证:∵294与84都是偶数可同时除以2,
即取147与42的最大公约数后再乘2.
147-42=105.
105-42=63.
63-42=21.
42-21=21.
∴294与84的最大公约数为21×2=42.
【总结升华】比较辗转相除法与更相减损术的区别
(1)都是求最大公约数的方法,计算上辗转相除法以除法为主,更相减损术以减法为主,计算次数上辗转相除法计算次数相对较少,特别当两个数字大小区别较大时计算次数的区别较明显;
(2)从结果体现形式来看,辗转相除法体现结果是以相除余数为0则得到,而更相减损术则以减数与差相等而得到.
由该题可以看出,辗转相除法得最大公约数的步骤较少.
对比两种方法控制好算法的结束,辗转相除法是到达余数为0,更相减损术是到达减数和差相等.
举一反三:
【变式1】(1)用辗转相除法求123和48的最大公约数.
(2)分别用辗转相除法和更相减损术求105与357的最大公约数.
【答案】21
【解析】(1)123=2×48+27
  48=1×27+21
  27=1×21+6
  21=3×6+3
  6=2×3+0
最后6能被3整除,得123和48的最大公约数为3.
(2)辗转相除法:357=105×3+42,105=42×2+21,42=21×2.
故105与357的最大公约数为21.
更相减损术:357-105=252,252-105=147,147-105=42,105-42=63,63-42=21,42-21=21.
故105与357的最大公约数为21.
例2.求三个数:168,54,264的最大公约数.
【思路点拨】运用更相减损术或辗转相除法,先求168与54的最大公约数a,再求a与264的最大公约数.
【答案】6
【解析】
采用更相减损术先求168与54的最大公约数.
(168,54)→(114,54)→(60,54)→(6,54)→(6,48)→(6,42)→(6,36)→(6,30)→(6,24)→(6,18)→(6,12)→(6,6)
故168与54的最大公约数为6.
采用辗转相除法求6和264的最大公约数.
因为264=44×6+0,所以6为264与6的最大公约数,也是三个数的最大公约数.
【总结升华】求最大公约数通常有两种方法:一是辗转相除法;二是更相减损术,对于3个数的最大公约数的求法,则是先求其中两个数的最大公约数m,再求m与第三个数的最大公约数.同样可推广到求3个数以上的数的最大公约数.
举一反三:
【变式1】求三个数324,243,135的最大公约数.
【解析】∵324=243×1+81,
243=81×3+0,
∴324与243的最大公约数为81.
又135=81×1+54,
81=54×1+27,
54=27×2+0,
∴81与135的最大公约数为27.
∴三个数324,243,135的最大公约数为27.
更相减损术:
∵324-243=81,
243-81=162,
162-81=81,
∴81是324和243的最大公约数.
又135-81=54,
81-54=27,
54-27=27,
∴27是81与135的最大公约数.
∴三个数324,243,135的最大公约数为27.
类型二:秦九韶算法
例3.(2018秋 福建月考)利用秦九韶算法计算在x=5时的值.
【思路点拨】据秦九韶算法,把多项式改写为f(x)=((((x+2)x+3)x+4)x+5)x+6.按照从内到外的顺序,依次计算x=5时的值,即可得出.
【答案】4881.
【解析】依据秦九韶算法,把多项式改写为f(x)=((((x+2)x+3)x+4)x+5)x+6.
按照从内到外的顺序,依次计算x=5的值:






故f(5)=4881.
【总结升华】利用秦九韶算法计算多项式的值的关键是能正确地将所给多项式改写,然后由内向外逐层计算,由于下一次计算需用到上一次的结果,故应认真、细心,确保中间结果的准确性.
举一反三:
【变式1】(2017秋 河北张家口月考)用秦九韶算法计算多项式
在x=―4时的V4值.
【答案】-220.
【解析】f(x)=(((((3x+5)x+6)x+79)x―8)x+35)x+12,
v0=3,
v1=3×(―4)+5=―7,
v2=(-7)×(―4)+6=34,
v3=34×(―4)+79=―57,
v4=―57×(―4)―8=-220.
【变式2】用秦九韶算法计算多项式在x=0.4时的值时,需做加法和乘法的次数和是( )
A.10 B.9 C.12 D.8
【答案】 C
【解析】 .
∴加法6次,乘法6次,
∴6+6=12(次),故选C.
类型三:进位制
例4.把87化为二进制数.
【答案】1010111(2)
【解析】 因为87=2×43+1,43=2×21+1,21=2×10+1,10=2×5+0,5=2×2+1,2=2×1+0.1=2×0+1.
所以87=2×(2×(2×(2×(2×2+1)+0)+1)+1)+1
=2×(2×(2×(2×(22+1)+0)+1)+1)+1
=…
=1×26+0×25+1×24+0×23+1×22+1×2+1
=1010111(2).
【总结升华】(1)本题的算法叫除2取余法.上述解法可以推广到把十进制数化为k进制数的算法,称为除k取余法.
(2)本题还可以用下面的除法算式表示如图:
把上式各步所得的余数从下到上排列,得87=1010111(2).
举一反三:
【变式】(1)将十进制数2l转化为五进制数.
(2)把十进制数48转化为二进制数.

【解析】(1)用除5取余法,可得
/
∴21=41(5).
(2) 将十进制数48转化为二进制数的除法算式如图所示.
把上式中各步所得的余数从下到上排列,得到48=110000(2).
【总结升华】在解答过程中常会出现把上图中各步所得的余数从上到下排列的错误,应注意避免.
例5.把下列各数化为十进制数.
(1)20121(3);(2)20121(4).
【答案】(1)178 (2)537
【解析】 (1)20121(3)=2×34+0×33+1×32+2×3+1=178.
(2)20121(4)=2×44+0×43+1×42+2×4+1=537.
【总结升华】k进制数转化为十进制数的方法是把k进制数表示为各位上的数字与k的幂的乘积之和,从右边起,第i位数字对应k的幂为.
举一反三:
【变式1】在十进制中,,那么在五进制中数码2 004折合成十进制为( )
A.29 B.254 C.602 D.2 004
【答案】B
【解析】,故选B.
【变式2】将十进制数34换算成二进制数,即(34)10=________.
【答案】100010(2).
【解析】34÷2=17……0
17÷2=8……1
8÷2=4……0
4÷2=2……0
2÷2=1……0
1÷2=0……1
故34(10)=100010(2)
故答案为:100010(2).
【总结升华】在解答过程中常会出现把图中各步所得的余数从上到下排列的错误,应注意避免.
【巩固练习】
1.1337与382的最大公约数是( ).
A.3 B.382 C.191 D.201
2.用辗转相除法求得459和357的最大公约数是( ).
A.3 B.9 C.17 D.51
3. 用秦九韶算法求多项式当x=4时的值时,先算的是( ).
A.4×4=16 B.7×4=28 C.4×4×4=64 D.7×4+6=34
4.用秦九韶算法计算,需要加法(或减法)与乘法运算的次数分别为( ).
A.5,4 B.5,5 C.4,4 D.4,5
5.用秦九韶算法计算多项式
,当时,的值为
A.0 B.2 C.-2 D.4
6.(2018春 广东珠海期末)将二进制数11100(2)转化为四进制数,正确的是( )
A.120(4) B.130(4) C.200(4) D.202(4)
7. 已知一个k进制数132与十进制数30相等,那么k等于( ).
A.-7或4 B.-7 C.4 D.都不对
8. 下列各数中最小的数是( ).
A.85(9) B.210(6) C.1000(4) D.111111(2)
9.(2018春 湖南怀化期末)四进制数123(4)化为十进制数为________.
10. 三个数的最大公约数是 。
11.(2017 河北冀州市模拟)在不同的进位制之间的转化中,若132(k)=42(10),则k=________.
12.(2017春 福州月考)用秦九韶算法计算多项式,求当x=3时的值.
13.(2018秋 湖北汉川市期中)(1)利用辗转相除法求8251和6105的最大公约数
(2)利用秦九韶算法求多项式在x=3时的值.(两问都按算法写步骤方可得分)
14. 把“五进制”数转化为“十进制”数,再把它转化为“八进制”数。
【答案与解析】
1.【答案】C
【解析】 1337=382×3+191,382=191×2+0,1337与382的最大公约数为191。
2.【答案】D
【解析】 ∵459=357×1+102,357=102×3+51,102=51×2+0,即51为459和357的最大公约数。
3.【答案】D
【解析】因为,所以用秦九韶算法求多项式当x=4时的值时,先算的是7×4+6=34。
4.【答案】D
【解析】 n次多项式当最高次项的系数不为1时,需进行n次乘法,若各项均不为零,则需进行n次加法(或减法),缺一项就减少一次加法(或减法)运算,而这个五次多项式与5次项系数不为1,缺常数项。因而乘法次数为5次,加法(或减法)次数为5-1=4(次)。
5.【答案】 A
【解析】
,然后由内向外计算.
6.【答案】B
【解析】先将“二进制”数11100(2)化为十进制数为
然后将十进制的28化为四进制:
28÷4=7余0
7÷4=1余3
1÷4=0余1
所以结果是130(4)
故选:B.
7. 【答案】C
【解析】 ∵132(k)=1×k2+3k+2=30,∴k=-7或k=4。又∵k>0,∴k=4。故选C。
8. 【答案】 D
【解析】 ∵85(9)=8×9+5=77;
216(6)=2×62+1×6=78;1000(4)=1×43=64;
111111(2)=1×25+1×24+1×23+1×22+1×2+1=63。
因此111111(2)最小,故选D。
9.【答案】27
【解析】由题,,
故答案为:27.
10. 【答案】
【解析】
11.【答案】5
【解析】∵132(k)=42(10),
∴ ,
解得:k=5,或k=-8(舍去),
故答案为:5
12.【答案】1642
【解析】f(x)=((((5x+4)x+3)x+2)x+1)x+1
当x=3时
v0=5
v1=5×3+4=19
v2=19×3+3=60
v3=60×3+2=182
v4=182×3+1=547
v5=547×3+1=1642
所以当x=2时,f(3)=1642
13.【答案】(1)37;(2)364
【解析】(1)8251=6105×1+2145
6105=2146×2+1813
2146=1813×1+333
333=148×2+37
148=37×4
所以8251与6105的最大公约数就是37
(2)
当x=3时






14. 【答案】194 302
【解析】