输入:
第1行.:测试数据的组数
第2行:两个整数
#include <stdio.h>
#include <string.h>int reserve(char *num,int len) //颠倒数组中的元素
{
int i = 0,low = 0,high = len-1;
char c;
while(low < high)
{
c = num[low];
num[low] = num[high];
num[high] = c;
low ++;
high --;
}
return 0;
}
int main()
{
int n,len_1,len_2,i = 0,j = 0;
char num_1[1000],num_2[1000],result[1000];
scanf("%d",&n);
for(j = 1; j <= n; j++)
{
for(i = 0; i < 1000; i ++)
{
result[i] = '0';
}
scanf("%s%s",num_1,num_2);
len_1 = strlen(num_1);
len_2 = strlen(num_2);
printf("Case %d:\n",j);
printf("%s + %s = ",num_2);
reserve(num_1,len_1);
reserve(num_2,len_2);
if(len_1 < len_2) //数组num_1比数组num_2短
{
for(i = len_1; i < len_2; i++) //使两个数组等长,短的数组后面添0
num_1[i] = '0';
for(i = 0; i < len_2; i ++)
{
result[i] += (num_1[i] + num_2[i] - 96);
if(result[i] > 57)
{
result[i] = ((result[i] - 48) % 10) + 48;
result[i+1] ++;
}
}
if(result[len_2] != '0') //如果数组的最高位发生进位
printf("%c",result[len_2]);
for(i = len_2 - 1; i >= 0; i --)
printf("%c",result[i]);
}
else
{
for(i = len_2; i < len_1; i++)
num_2[i] = '0';
for(i = 0; i < len_1; i ++)
{
result[i] += (num_1[i] + num_2[i] - 96);
if(result[i] > 57)
{
result[i] = ((result[i] - 48) % 10) + 48;
result[i+1] ++;
}
}
if(result[len_1] != '0')
printf("%c",result[len_1]);
for(i = len_1 - 1; i >= 0; i --)
printf("%c",result[i]);
}
printf("\n");
if(j != n)
printf("\n");
}
return 0;
}
如果大家有更好的方法请告诉我,谢谢。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。