- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
更相减损术求最大公约数的步骤如下
下面我们来用一个具体的例子来分析: 例4.将二进制数110 011(2)化成十进制数 解 根据k进制数的实际意义,我们可以这样来转换: INPUT a,b,c i=1 b=0 WHILE i=n t=GET a[i] b=b+t*k^(i-1) i=i+1 WEND PRINT b END GET函数用于取出a的有数第i位 例5.不89化为二进制数 分析:89=2×(2×(2×(2×(2×2+1)+1)+0)+0)+1 =… =1 011 001(2) 2 89 1 2 44 0 2 22 0 2 11 1 2 5 1 2 2 0 2 1 1 0 所以上式可以表示为:1 011 001 综合:上述方法叫做k进制数的除k取余法 5.把89化为五进制数 思考:1如何将十六进制数A1F721化为二进制数 一般方法: k进制数 十进制数 n进制数 1010 0001 1111 0111 0010 0001 算法 程序图框 算法语句 辗转相除与更相减损术 秦 九 韶 算 法 进 位 制 基本结构 流程图 顺序结构 变量与赋值 循环结构 基本语句 循环语句 条件语句 WHILE语句 UNTIL语句 IF-THEN语句 语句适用结构 算法 条件结构 我们这节课就利用基本的算法程序来解决一些实际问题,进一步体会算法的程序思想。 案例1.辗转相除法与更相减损术 在初中,我们已经学过求最大公约数的知识,你能求出18与30的最大公约数吗? 2 30 3 9 15 3 5 所以,18和30的最大公约数是:2×3=6 互质 因数 但是,当我们处理较大数(如:8251与6105)的最大公因数时,如果利用这种方法可能计算量比较大,步骤比较多。下面我们介绍一种古老而有效的算法——辗转相除法 这种算法是欧几里得公元前300年左右首先提出的,因此又叫欧几里得算法 例1 求两个正数8251和6105的最大公约数。 分析:8251与6105两数都比较大,而且没有明显的公约数,如能把它们都变小一点,根据已有的知识即可求出最大公约数 解 8251=6105×1+2146 显然8251和6105的最大公约数也必是2146的约数,同样6105与2146的公约数也必是8251的约数,所以8251与6105的最大公约数也是6105与2146的最大公约数 继续下去,我们得到: 欧几里得(公元前330-公元前275):古希腊数学家,雅典人 欧几里得是柏拉图的学生,长期在亚历山大里亚教书。 公元前300年左右,代表作《几何原本》13卷问世,创立了著名的欧氏几何,至今仍为中学生必学的一门基础知识。欧几里得对光学也有一定研究。 6105=2146×2+18132146=1813×1+3331813=333×5+148333=148×2+37148=37×4+0则37为8251与6105的最大公约数 这就是辗转相除法,有除法的性质可以知道,对于任意两个正整数,上述除法步骤总可以在有限步骤之后完成 利用辗转相除法求最大公约数的步骤如下: 第一步:用较大的数m除以较小的数n得到一个商q0和一个余数r0; 第二步:若r0=0,则n为m,n的最大公约数;若r0≠0,则用除数n除以余数r0得到一个商q1和一个余数r1; 第三步:若r1=0,则r1为m,n的最大公约数;若r1≠0,则用除数r0除以余数r1得到一个商q2和一个余数r2 第n步:依次计算直至rn=0,此时所得到的rn-1即为所求的最大公约数 ……………… r= m MOD n m=n n=r r=o? 否 是 程序图框 带余除法 INPUT “请输入m,n的值”;m,n IF mn THEN a=m m=n n=a END IF DO r=m MOD N m=n n=r LOOP UNTIL r=0 PRINT m END 作用是什么? 为什么要用直到型循环结构? 思考:如果用当型循环结构构造算法,则用辗转相除法求两个正整数m,n的最大公约数的程序框图和程序分别如何表示? 开始 输入m,n 求m除以n的余数r m=n n0? 否 输出m 结束 是 n=r INPUT m,n WHILE n0 r=m MOD n m=n n=r WEND PRINT m END 1.利用辗转相除法求两数4081与20723的最大公约数 ,写出它的流程框图和BASIC程序 更相减损
文档评论(0)