基本算法(pascal版).doc

  1. 1、本文档共50页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
一、高精度乘法 1.高精度乘单精度(1位数) 程序如下: program HighPrecision3_Multiply1; const maxlen=100; { max length of the number } type hp=record len:integer; { length of the number } s:array[1..maxlen] of integer; end; var x,y:hp; { x:input hp ; y:output } z:integer; { z:input lp } procedure PrintHP(const p:hp); var i:integer; begin for i:=p.len downto 1 do write(p.s[i]); end; procedure init; var st:string; i:integer; begin readln(st); x.len:=length(st); for i:=1 to x.len do { change string to HP } x.s[i]:=ord(st[x.len+1-i])-ord(0); readln(z); end; procedure Multiply(a:hp;b:integer;var c:hp); { c:=a*b } var i,len:integer; begin fillchar(c,sizeof(c),0); len:=a.len; for i:=1 to len do begin inc(c.s[i],a.s[i]*b); inc(c.s[i+1],c.s[i] div 10); c.s[i]:=c.s[i] mod 10; end; inc(len); while(c.s[len]=10) do begin inc(c.s[len+1],c.s[len] div 10); c.s[len]=c.s[len] mod 10; inc(len); end; while(len1) and (c.s[len]=0) do dec(len); c.len:=len; end; procedure main; begin Multiply(x,z,y); end; procedure out; begin PrintHP(y); writeln; end; begin init; main; out; end. 2.高精度乘一个整型数据(integer) 只需要将上述程序的hp类型定义如下即可: type hp=record len:integer { length of the number } s:array[1..maxlen] of longint { s[1] is the lowest position s[len] is the highest position } end; 3.高精度乘高精度 程序如下: program HighPrecision4_Multiply2; const maxlen=100; { max length of the number } type hp=record len:integer; { length of the number } s:array[1..maxlen] of integer end; var x:array[1..2] of hp; y:hp; { x:input ; y:output } procedure PrintHP(const p:hp); var i:integer; begin for i:=p.len downto 1 do write(p.s[i]); end; procedure init; var st:string; j,i:integer; begin for j:=1 to 2 do begin readln(st); x[j].le

文档评论(0)

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

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

1亿VIP精品文档

相关文档