#define MAX 110
/*******************************
*大整数的加法
*参数:s1,s2为两个以字符串存储的加数
*返回值:无
*******************************/
char result[MAX];
void big_num_add(char * s1,char * s2)
{
int max_len,len1,len2;
int i,k;
char * a;
char * b;
len1 = strlen(s1);
len2 = strlen(s2);
max_len = len1 > len2?len1 : len2;
a = (char *)malloc(max_len + 1);//暂存s1
b = (char *)malloc(max_len + 1);//暂存s2
memset(a,0,max_len + 1);
memset(b,0,max_len + 1);
k = 0;
for(i = len1 - 1;i >= 0;i--) a[k++] = s1[i] - '0';//倒置存放
k = 0;
for(i = len2 - 1;i >= 0;i--) b[k++] = s2[i] - '0';//倒置存放
for(i = 0;i < max_len;i++)
{
a[i] += b[i];
if(a[i] > 9)
{
a[i] = a[i] - 10;
a[i + 1]++;
}
}
if(a[max_len] != 0) max_len++;
k = 0;
for(i = max_len - 1;i >= 0;i--) result[k++] = a[i] + '0';
result[k] = '\0';
free(a);
free(b);
}
大整数加法函数
最新推荐文章于 2024-03-12 11:38:34 发布