注意:
在main函数计算过程中必须注意前导0;
string字符串进行计算:(还有待优化)
string add(string s1,string s2)
{
string max,min;
if(s1.length()>s2.length())
{
max=s1;min=s2;
}
else
{
max=s2;min=s1;
}
int l1=max.length(),l2=min.length();
for(int i=l1-1,j=l2-1;j>=0;i--,j--)
max[i]+=min[j]-'0';
for(int i=l1-1;i>=1;i--)
if(max[i]>'9')
{
max[i]-=10;
max[i-1]++;
}
if(max[0]>'9')
{
max[0]-=10;
max='1'+max;
}
return max;
}
char字符串进行计算:
#include <stdio.h>
#include <string.h>
#define BASE 10
#define N 200
char a[N+1], b[N+1];
char ans[N+1];
int main(void)
{
int anslen, carry, len, i, j;
scanf("%s", a);
scanf("%s", b);
memset(ans, 0, sizeof(ans));
anslen = len = strlen(a);
for(i=len-1, j=0; i>=0; i--)
ans[j++] = a[i] - '0';
len = strlen(b);
if(len > anslen)
anslen = len;
carry = 0;
for(i=len-1, j=0; i>=0; i--,j++) {
ans[j] += b[i] - '0' + carry;
carry = ans[j] / BASE;
ans[j] %= BASE;
}
while(carry > 0) {
ans[j] += carry;
carry = ans[j] / BASE;
ans[j++] %= BASE;
}
if(j > anslen)
anslen = j;
/* 去除前导的多个0 */
for(i=anslen-1; i>=0; i--)
if(ans[i])
break;
if(i < 0)
i = 0;
/* 输出结果 */
for(; i>=0; i--)
printf("%d", ans[i]);
printf("\n");
return 0;
}