高精度计算-安阳一中.DOC

  1. 1、本文档共5页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
高精度计算-安阳一中

安阳一中信息学奥赛辅导资料 第 PAGE 4 页 共 NUMPAGES 5 页 高精度计算(2) 教学目标 熟练掌握高精度乘除计算 重点难点分析 高精度乘法的实现; 教具或课件 使用多媒体演示文稿 主要教学过程 引入新课 本节主要介绍高精度乘法的相关内容。 教学过程设计 【例3】 高精度乘法。从键盘读入两个正整数,求它们的积。 分析:(1)、乘法运算a←a*c(a为高精度类型,c为字节型) 按照乘法规则,从a的第l位开始逐位与c相乘。在第i位乘法运算中(1≤i≤la),a的i位与c的乘积必须加上i-1位的进位(i-1位的乘积除以10的整商),然后规整积的i-l位(取i-1位的乘积对10的余数)。 procedure multiply(var a:numtype; c:byte); var i:byte; begin a[1] ←a[l]*c; {第1位初始化} for i←2 to la do {逐位相乘} begin a[i] ←a[i]*c; a[i] ←a[i]+a[i-l] div 10; a[i-1] ←a[i-l] mod 10 end:{for} while a[1a]=10 do {积的最高位进位} begin la←la+1; a[la] ←a[la-1] div 10; a[la-1] ←a[la-1]mod 10; end; {while} end;{multiply} (2)、乘法运算c←a*b(a,b为高精度类型,) 类似加法,可以用竖式求乘法。在做乘法运算时,同样也有进位,同时对每一位进乘法运算时,必须进行错位相加,如图3, 图4。 分析C 数组下标的变化规律,可以写出如下关系式:C i = C i +C i +…由此可见,C i跟A[i]*B[j]乘积有关,跟上次的进位有关,还跟原C i的值有关,分析下标规律,有 x:= A[i]*B[j]+ x DIV 10+ C[i+j-1]; C[i+j-1] := x mod 10; 类似,高精度乘法的参考程序: program exam3; const max=200; var a,b,c:array[1..max] of 0..9; n1,n2:string; lena,lenb,lenc,i,j,x:integer; begin write(’Input multiplier:’); readln(n1); write(’Input multiplicand:’); readln(n2); lena:=length(n1); lenb:=length(n2); for i:=1 to lena do a[lena-i+1]:=ord(n1[i])-ord(’0’); for i:=1 to lenb do b[lenb-i+1]:=ord(n2[i])-ord(’0’); for i:=1 to lena do begin x:=0; for j:=1 to lenb do begin {对乘数的每一位进行处理} x := a[i]*b[j] + x div 10 + c[i+j-1]; {当前乘积+上次乘积进位+原数} c[i+j-1] := x mod 10; end; c[i+j]:= x div 10; {进位} end; lenc:=i+j; while (c[lenc]=0) and (lenc1) do dec(lenc); for i:=lenc downto 1 do write(c[i]); writeln end. 【例4】 高精度除法。从键盘读入两个正整数,求它们的商(做整除)。 分析:做除法时,每一次上商的值都在0~9,每次求得的余数连接以后的若干位得到新的被除数,继续做除法。因此,在做高精度除法时,要涉及到乘法运算和减法运算,还有移位处理。当然,为了程序简洁,可以避免高精度乘法,用0~9 次循环减法取代得到商的值。这里,我们讨论一下高精度数除以单精度数的结果,采取的方法是按位相除法。 program exam4; const max=200; var a,c:array[1..max] of 0..9; x,b:longint; n1,n2:string; lena:integer; code,i,j:integer; begin write(’Input dividend:’); readln(n1); write(’Input divisor:’); readln(n2); lena:=le

文档评论(0)

zhaoxiaoj + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档