野火电子论坛

 找回密码
 注册

QQ登录

只需一步,快速开始

查看: 6094|回复: 0

大数运算加法

[复制链接]
发表于 2020-5-19 20:12:54 | 显示全部楼层 |阅读模式
  1. #include <stdio.h>
  2. #include <stdlib.h>
  3. #include <string.h>

  4. typedef int bool;
  5. #define false (-1)
  6. #define true (0)

  7. static bool char_check(char c) {
  8.     if (c > '9') {
  9.         return false;
  10.     }
  11.     if (c < '0') {
  12.         return false;
  13.     }
  14.     return true;
  15. }

  16. static bool str_check(const char* src) {
  17.     for ( ; *src; src++) {
  18.         if (false == char_check(*src)) {
  19.             return false;
  20.         }
  21.     }
  22.     return true;
  23. }

  24. static void str_reverse(char* s) {
  25.     char temp;
  26.     char* r = s + strlen(s) - 1;
  27.     while (s < r) {
  28.         temp = *s;
  29.         *s++ = *r;
  30.         *r-- = temp;
  31.     }
  32. }

  33. static bool char_add(char a, char b, char* c, char* d) {
  34.     if (false == char_check(a)) {
  35.         return false;
  36.     }
  37.     if (false == char_check(b)) {
  38.         return false;
  39.     }
  40.     a -= '0';
  41.     b -= '0';
  42.     *d = a + b + (*c);
  43.     if (*d > 9) {
  44.         *d -= 10;
  45.         *c = 1;
  46.     }
  47.     else {
  48.         *c = 0;
  49.     }
  50.     *d += '0';
  51.     return true;
  52. }

  53. static bool str_add(const char* a, const char* b, char* d) {
  54.     char aa, bb, c = 0;
  55.     int len_a = strlen(a), len_b = strlen(b);
  56.     char* p_a = a + len_a - 1;
  57.     char* p_b = b + len_b - 1;
  58.     char* p_d = d;
  59.     if (false == str_check(a)) {
  60.         return false;
  61.     }
  62.     if (false == str_check(b)) {
  63.         return false;
  64.     }
  65.     for ( ; (len_a > 0) || (len_b > 0); ) {
  66.         aa = len_a > 0? *p_a-- : '0';
  67.         bb = len_b > 0? *p_b-- : '0';
  68.         char_add(aa, bb, &c, p_d++);
  69.         len_a--;
  70.         len_b--;
  71.     }
  72.     str_reverse(d);
  73.     return true;
  74. }

  75. int main()
  76. {
  77.     char* a = "16664129129421912941294";
  78.     char* b = "34666666666543854397591";
  79.     char c[100] = "";
  80.     str_add(a, b, c);
  81.     printf("%s!\n", c);
  82.     return 0;
  83. }
复制代码



回复

使用道具 举报

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

本版积分规则

联系站长|手机版|野火电子官网|野火淘宝店铺|野火电子论坛 ( 粤ICP备14069197号 ) 大学生ARM嵌入式2群

GMT+8, 2024-4-24 12:12 , Processed in 0.046722 second(s), 23 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

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