高精度加减乘除阶乘计算的算法及代码.pdf

高精度加减乘除阶乘计算的算法及代码.pdf

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

高精度计算 主要的方法是利用数组模拟计算比如: 高精度加法 12345678910111213 + 1111111111111111111 开两个数组存储: a[]={3,1,2,1,1,1,0,1,9,8,7,6,5,4,3,2,1}; b[]={1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1}; 两个数组分别把数值倒存,在一位一位的加,每位加后判断是否大于 10,在进位(注:如果太大的数 值,可以考虑4 位一存哦.) 注意下面的a1,b1,c1 为 数组的长度 if a1b1 then c1:=a1 else c1:=b1; for i:=1 to c1 do begin c[i]:=a[i]+b [i]+c[i]; c[i+1]:=c[i+1]+c[i]div 10; c[i]:=c[i] mod 10; end; while c[c1+1]0 do begin inc(c1); c[c1+1]:=c[c1+1]+c[c1]div 10; c[c1]:=c[c1] mod 10; end; 四位一存: var s:ansistring ; a,b:array [1..11000]of int64; x:array [1..51000]of int64; c:array [1..35000]of int64; i,j,a1,b1,c1,d,x1:longint; begin while not eof do begin fillchar(c,sizeof(c),0); readln (s); x1:=length(s); for i:=1 to x1 do x[i]:=ord (s[x1-i+1])-48; for i:=1 to (x1 div 5) do a[i]:=x[5*i]*10000+x[5*i-1]*1000+x[5*i-2]*100+x[5*i-3]*10+x[5*i-4]; a1:=x1 div 5; if x1 mod 50 then begin d:=0; for i:=1 to x1 mod 5 do d:=d*10+x[x1-i+1]; a1:=a1+1; a[a1]:=d; end; readln (s); fillchar(x,sizeof(x),0); x1:=length(s); for i:=1 to x1 do x[i]:=ord (s[x1-i+1])-48; for i:=1 to (x1 div 5) do b [i]:=x[5*i]*10000+x[5*i-1]*1000+x[5*i-2]*100+x[5*i-3]*10+x[5*i-4]; b1:=x1 div 5; if x1 mod 50 then begin d:=0; for i:=1 to x1 mod 5 do d:=d*10+x[x1-i+1]; b1:=b1+1; b [b1]:=d; end; for i:=1 to a1 do for j:=1 to b1 do c[i+j-1]:=c[i+j-1]+a[i]*b [j]; c1:=a1+b1-1; for i:=1 to c1 do if c[i]99999 then begin c[i+1]:=c[i+1]+c[i] div 100000; c[i]:=c[i] mod 100000; end; while c[c1+1]0 do

文档评论(0)

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

教师资格证持证人

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

领域认证该用户于2024年04月12日上传了教师资格证

1亿VIP精品文档

相关文档