鱼C论坛

 找回密码
 立即注册
查看: 2318|回复: 5

超大型数据加减法问题

[复制链接]
发表于 2021-11-8 21:36:19 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
背景:
计算机所能完成的一个基本功能就是完成数据的计算,譬如加法、减法等等。但是在任何一种计算机上,计算中能够使用的数字都是有一定范围的,超过了范围,就没法得到精确的结果。

你现在接受了一个任务,要编写一个高精度计算器的核心部分。所谓高精度计算器,就是可以计算很大很大的数据的计算器。

输入:
输入的第一行是一个正整数,表示下面有几组数据需要计算。之后的每一行是两个十进制的正整数和一个运算符,每个整数可以由最多 500 个数字组成。运算符可以是加号或者减号。

输出:
对应着输入的每一行数据,输出计算的结果,每个结果占一行。

用例1:
   输入:
   2(回车)
   213914+23466123(回车)
   32862934-23481243(回车)

   输出:
   23680037(回车)
   9381691(回车)

用例2:
   输入:
   3(回车)
   483291674192731231+1236187236812735123(回车)
   123129678463287562378-28935687264871236(回车)
   999999999+1(回车)
   输出:
   1719478911005466354(回车)
   123100742776022691142(回车)
   1000000000(回车)

感谢各位大佬!!!!!!!
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2021-11-8 22:47:41 | 显示全部楼层
题目也没有说不能调用库函数,所以这里我就调用库函数算了
  1. #include <stdio.h>
  2. #include <mpfr.h>
  3. #include <ctype.h>

  4. void output(void) {
  5.     char buff[8192]; fgets(buff, 8192, stdin);
  6.     mpfr_t a, b, c;
  7.     char *op = NULL;
  8.     mpfr_inits2(8192, a, b, c, NULL);
  9.     for(size_t i = 0; buff[i]; ++i) {
  10.         if(!isdigit(buff[i])) {
  11.             op = &buff[i];
  12.             break;
  13.         }
  14.     }
  15.     mpfr_strtofr(a, buff, &op, 10, MPFR_RNDD);
  16.     mpfr_set_str(b, op + 1, 10, MPFR_RNDD);
  17.     if(*op == '-') mpfr_neg(b, b, MPFR_RNDD);
  18.     mpfr_add(c, a, b, MPFR_RNDD);
  19.     mpfr_printf("%.0Rf\n", c);
  20.     mpfr_clears(a, b, c, NULL);
  21.     mpfr_free_cache();
  22. }

  23. int main(void) {
  24.     size_t count; scanf("%lu", &count);
  25.     getchar();
  26.     for(size_t i = 0; i < count; ++i) {
  27.         output();
  28.     }
  29.     return 0;
  30. }
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2021-11-9 11:33:03 | 显示全部楼层
人造人 发表于 2021-11-8 22:47
题目也没有说不能调用库函数,所以这里我就调用库函数算了

不允许调用库函数
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2021-11-9 12:29:08 | 显示全部楼层

为什么?
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2021-11-9 14:39:59 | 显示全部楼层
要不去参考一下Python底层对超长整型的实现?
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2021-11-9 16:38:54 | 显示全部楼层
本帖最后由 jhq999 于 2021-11-9 16:59 编辑

我这个思路,不知道有多少BUG ,目前知道一个,就是减法时数位相同前面小于后面,我懒得调换了。
  1. int DivStr(char* inch,char* valch1,char* valch2,char *sg);
  2. int Bigoperation(char* valch1,char* valch2,char sg,char* valch3);
  3. int main()
  4. {
  5.         char invalch[64]={0},valch[3][64]={0},sg=0;
  6.         int i=0,j=0,sgd=0;
  7.         scanf("%s",invalch);
  8.         if(!(sgd=DivStr(invalch,valch[0],valch[1],&sg)))return 0;
  9.         if(sgd)
  10.         {
  11.                 if (-1==sgd)
  12.                 {
  13.                         if(Bigoperation(valch[1],valch[0],sg,valch[2]))
  14.                         {
  15.                                 if('-'==sg)printf("-");
  16.                                 while (valch[2][++i]);
  17.                                 for (; i>=0; i--)
  18.                                 {
  19.                                         printf("%c",valch[2][i]);
  20.                                 }
  21.                         }

  22.                 }
  23.                 else if (1==sgd)
  24.                 {
  25.                         if(Bigoperation(valch[0],valch[1],sg,valch[2]))
  26.                         {
  27.                                 while (valch[2][++i]);
  28.                                 for (; i>=0; i--)
  29.                                 {
  30.                                         printf("%c",valch[2][i]);
  31.                                 }
  32.                         }

  33.                 }
  34.         }

  35.         return 0;
  36. }
  37. int Bigoperation(char* valch1,char* valch2,char sg,char* valch3)
  38. {
  39.         int i=0,j=0,k=0;
  40.         if ('+'==sg)
  41.         {
  42.                 for (i = 0,j=0;valch1[i]||valch2[j]; i++,j++)
  43.                 {
  44.                         if ('\0'==valch1[i])
  45.                         {
  46.                                 i--;
  47.                         }
  48.                         if ('\0'==valch2[j])
  49.                         {
  50.                                 j--;
  51.                         }
  52.                         if (i==j)
  53.                         {
  54.                                 valch3[i]+=valch1[i]+valch2[j]-'0';

  55.                         }
  56.                         else if (i>j)
  57.                         {
  58.                                 valch3[i]+=valch1[i];
  59.                         }
  60.                         else
  61.                         {
  62.                                 valch3[j]+=valch2[j];
  63.                         }
  64.                         int k=i;
  65.                         if (k<j)k=j;
  66.                         if (valch3[k]>'9')
  67.                         {
  68.                                 valch3[k]-=0xa;
  69.                                 valch3[k+1]++;
  70.                         }
  71.                 }
  72.                 i=i>j?i:j;

  73.                 while(valch3[i])i++;
  74.                 i--;
  75.                 if (valch3[i]>'9')
  76.                 {
  77.                         valch3[i]-=0xa;
  78.                 }
  79.                 else if(valch3[i]<'0')
  80.                 {
  81.                         valch3[i]+='0';
  82.                 }
  83.                 return 1;
  84.         }
  85.         if ('-'==sg)
  86.         {
  87.                 for (i = 0,j=0;valch1[i]||valch2[j]; i++,j++)
  88.                 {
  89.                         if ('\0'==valch1[i])
  90.                         {
  91.                                 i--;
  92.                         }
  93.                         if ('\0'==valch2[j])
  94.                         {
  95.                                 j--;
  96.                         }
  97.                         if (i==j)
  98.                         {
  99.                                 valch3[i]+=valch1[i]-valch2[j]+'0';

  100.                         }
  101.                         else if (i>j)
  102.                         {
  103.                                 valch3[i]+=valch1[i];
  104.                         }
  105.                         else
  106.                         {
  107.                                 valch3[j]+=valch2[j];
  108.                         }
  109.                         k=i;
  110.                         if (k<j)k=j;
  111.                         if (valch3[k]<'0')
  112.                         {
  113.                                 valch3[k]=0x3a-'0'+valch3[k];
  114.                                 valch3[k+1]--;
  115.                         }
  116.                 }
  117.                 if (valch3[k]=='0')
  118.                 {
  119.                         valch3[k]='\0';
  120.                 }
  121.                 return 1;
  122.         }
  123.         return 0;
  124. }
  125. int DivStr(char* inch,char* valch1,char* valch2,char *sg)
  126. {
  127.         int i=0,j=0,sgd=1;
  128.         while ('+'!=inch[j]&&'-'!=inch[j])j++;
  129.         for (i = 0; i < j; i++)
  130.         {
  131.                 valch1[j-1-i]=inch[i];
  132.                 if ('0'>inch[i]||'9'<inch[i])
  133.                 {
  134.                         return 0;
  135.                 }
  136.         }
  137.         *sg=inch[i];
  138.         sgd=i;
  139.         inch[i]='\0';
  140.         j=i+1;
  141.         while (inch[j])j++;
  142.         if ((sgd-1)<(j-sgd))sgd=-1;//就是这里
  143.         else
  144.                 sgd=1;
  145.         for (i=0,j--; inch[j]; j--,i++)
  146.         {
  147.                 valch2[i]=inch[j];
  148.                 if ('0'>inch[j]||'9'<inch[j])
  149.                 {
  150.                         return 0;
  151.                 }
  152.         }
  153.         return sgd;
  154. }
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-4-25 22:35

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表