高精度整数加法运算(C语言).pdfVIP

  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文档。上传文档
查看更多
高精度整数加法运算(C语言)

高精度整数加法运算   因为是任意长的二整数求和,而系统中整型数的精度有限,因此需用字符串形式存储整数,并按位逐 位进行运算,运算过程中需考虑进位和借位问题。再者,整数可以是负数,若二整数符号相同则为加法运 算,相异则实为减法运算,若是减法运算还需比较二数的绝对值大小,以确定最终结果的符号及减数与被 减数的安排顺序。   完整程序如下: /* ********************************************************  * name: add.c * author: Joshua Chan * description: 对二个随意长度的整数进行加法运算 以程序参数的形式输入二个随意长度整数(可为负整数) 程序会输出其加法运算的结果 * *******************************************************/ #include stdio.h #include string.h #define MAX_LEN 80 /* 将字符 0~9 转化为数字 0~9 */ static int ctoi(char c) { return (c - 0); } /* * 实现二个整数字符串的加法运算,要求二整数符号相同 */ static void _add(const char *num1, const char *num2, char *result) { int i, j, k, n1, n2, n; int len1, len2; int sig; int sta; /* 进位标识 */ int car; char c[MAX_LEN] = {0}; /* 判断输入整数的正负号 */ sig = (*num1 == -) ? -1 : 1; /* 判断有效数字起始位置 */ sta = (sig == -1) ? 1 : 0; len1 = strlen(num1); len2 = strlen(num2); /* * 对二整数自低位起进行逐位相加,逢十进位,计算结果逐位存入临时数组 * 比较二整数长度,以大者长度作为循环相加次数 */ if (len1 = len2) { j = len2 - 1; k = 0; car = 0; for (i = len1-1; i = sta; i--) { n1 = ctoi(num1[i]); n2 = (j = sta) ? (ctoi(num2[j])) : 0; j--; n = (car == 1) ? (n1 + n2 + 1) : (n1 + n2); if (n 9) { n = n % 10; car = 1; } else car = 0; c[k] = n + 0; k++; } if (car == 1) { c[k] = 1 + 0; k++; } } else { j = len1 -1; k = 0; car = 0; for (i = len2-1; i =sta; i--) { n2 = ctoi(num2[i]); n1 = (j = sta) ? (ctoi(num1[j])) : 0; j--; n = (car == 1) ? (n1 + n2 + 1) : (n1 + n2); if (n 9) { n = n % 1

文档评论(0)

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

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

1亿VIP精品文档

相关文档