高精度讲义.pptVIP

  1. 1、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
高精度讲义

高精度算法基础篇 三、运算过程 例:35+86竖式相加   35 +  86 ------- 1----- 1 -----1--------- 21 -------------- 121 三、运算过程 (1)运算顺序:两个数靠右对齐;从低位向高位运算;先计算低位再计算高位; (2)运算规则:同一位的两个数相加再加上从低位来的进位,成为该位的和;这个和去掉向高位的进位就成为该位的值;如上例:3+8+1=12,向前一位进1,本位的值是2;可借助MOD、DIV运算完成这一步; (3)最后一位的进位:如果完成两个数的相加后,进位位值不为0,则应添加一位; (4)如果两个加数位数不一样多,则按位数多的一个进行计算; 分析: 分析: 例:高精度加法 输入两个整数x,y,输出它们的和。(0≤x,y≤ 10100) 算法: (用st读入两个数) 1、输入st,记录长度lx;将st中每个元素转化为整数反向保存在数组X[ ]中; 2、输入st,记录长度ly;将st中每个元素转化为整数反向保存在数组Y[ ]中; 3、如果lxly,则lx?ly(取最大长度保存在lx中) 4、求和并放在数组h[ ]中。 4-1、h[I]?h[I]+x[I]+y[I] 4-2、h[I+1]?h[I] div 10 4-3、h[I]?h[I] mod 10 5、反向输出。 样程 Program ex; var st:string; x,y,h:array [0..101] of integer; lx,ly,I:integer; begin for I:=1 to 101 do begin x[I]:=0;y[I]:=0;h[I]:=0;end; write(‘x=‘);readln(st);lx:=length(st); for I:=lx downto 1 do x[lx-I]:=ord(st[I])-ord(‘0’); write(‘y=‘);readln(st);ly:=length(st); for I:=ly downto 1 do y[ly-I]:=ord(st[I])-ord(‘0’); if lxly then lx:=ly; for I:=0 to lx do begin h[I]:=h[I]+x[i]+y[i]; h[I+1]:=h[I] div 10; h[I]:=h[I] mod 10; end; if h[lx]=0 then lx:=lx-1; write(‘h=‘); for I:=lx to 0 do write(h[I]); readln; End. 优化 以上的方法的有明显的缺点: (1)浪费空间:一个整型变量(-32768~32767)只存放一位(0~9); (2)浪费时间:一次加减只处理一位; 针对以上问题,我们做如下优化:一个数组元素存放四位数;(integer的最大范围是32767,5位的话可能导致出界)。 优化 改进算法: (1)运算时:不再逢十进位,而是逢万进位(mod 10000; div 10000); (2)输出时:最高位直接输出,其余各位,要判断是否足够4位,不足部分要补0;例如:求得的和是这样三段的数, 输出时,应该是100232345而不是1232345。 高精度算法提升篇 求回文数 若一个数(首位不为零)从左向右读与从右向左读都是一样,我们就将其称之为回文数。例如:给定一个10进制数56,将56加65(即把56从右向左读),得到的121是一个回文数。又如,对于10进制数87: STEP1:87+78=165 STEP2:165+561=726 STEP3:726+627=1353 STEP4:1353+3531=4884 在这里的一步是指进行了一次N进制的加法,上例最少用了4步得到回文数4884。 写一个程序,给定一个N(2≤N≤10,N=16)进制数m,m的位数上限为20。求最少经过几步可以得到回文数。如果在30步以内(包括30步)不可能得到回文数,则输出“impossible” 1.将数串s转化为整数数组m 设数串s=s1‥sp,串长为p。其中si为第p-i+1位n进制数(1≤i≤p)。我们将s转化为整数数组m=m[p]‥m[1],其中m[i]对应第i位n进制数。 type mtype=array[1..100]of integer; var m:mtype; 按下述方法将s转化为整数数组m: p←length(s);{计算s的串长} for i←1 to p do {从最高

文档评论(0)

zhuwenmeijiale + 关注
实名认证
文档贡献者

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

版权声明书
用户编号:7065136142000003

1亿VIP精品文档

相关文档