标签:
char* MaxAdd(char *str1,char *str2){
int len1=strlen(str1);
int len2=strlen(str2);
int num1[MAX]={0};
int num2[MAX]={0};
for(int j=0,i=len1-1;i>=0;i--,j++){
num1[j]=str1[i]-'0'; //转换为int数组
}
for(int j=0,i=len2-1;i>=0;i--,j++){
num2[j]=str2[i]-'0';
}
<span style="color:#ff0000;">for(int i=0;i<MAX;i++){
num1[i]+=num2[i];
if(num1[i]>9){ //处理有进位的情况
num1[i]-=10;
num1[i+1]++;
}
}</span>
int resultlen;
for(int i=MAX-1;i>=0;--i){
if(num1[i]!=0){
resultlen=i+2; //结果字符创长度需要加2
break;
}
}//找到第一个不为0的数
char *result=new char[resultlen];
int j=0;
for(int k=resultlen-2;k>=0;k--,j++){
result[j]=num1[k]+'0';
}
result[j]='\0';
return result;
}
大数相减基本都是采用字符数组处理,需要注意的是够不够减、结果中高位的0。对于小数减大数,都是用大数减小数,结果在前面加一个“—”符号就行了。
这里为方便点,假设是大数减小数。
void BigNum(char *str1, char *str2)
{
if(str1 == NULL || str2 == NULL)
return;
int len1 = strlen(str1);
int len2 = strlen(str2);
int i, j;
int *num1 = (int*)malloc(len1*sizeof(int));
int *num2 = (int*)malloc(len1*sizeof(int));
for (i = 0; i < len1; i++)
{
num1[i] = num2[i] = 0;
}
for (i = len1 - 1; i >= 0; i--)
{
num1[len1 - 1 - i] = str1[i] - '0';
}
for (i = len2 - 1; i >= 0; i--)
{
num2[len2-1-i] = str2[i] - '0';
}
<span style="color:#ff0000;">for (i = 0; i < len1; i++)
{
num1[i] = num1[i] - num2[i];
if(num1[i] < 0)
{
num1[i] = num1[i] + 10;
num1[i+1] = num1[i+1] - 1;
}
}</span>
for (i = len1-1; i>=0 && num1[i] == 0; i--)
;
if(i >= 0)
for (; i >= 0; i--)
{
printf("%d",num1[i]);
}
else
printf("0");
}标签:
原文地址:http://blog.csdn.net/sxhlovehmm/article/details/45056845