69,371
社区成员
发帖
与我相关
我的任务
分享
#include <stdio.h>
#include <string.h>
int main()
{
char a[1001],b[1001]; //a b 两个数
int c,i,j,k,s[1001]; //c 进位 i,j,k 下标 s[1001] 相加后的数
int n,count=1; //n 需输入组数 count 当前组数
scanf("%d%*c",&n);
while(n-->0)
{
scanf("%s%s",&a,&b);
k=0;
c=0;
for(i=strlen(a)-1,j=strlen(b)-1;i>=0&&j>=0;i--,j--)
{
s[k++]=(a[i]-'0'+b[j]-'0'+c)%10;
c=(a[i]-'0'+b[j]-'0'+c)/10;
}
if(i>=0) //如果a数长
for(;i>=0;i--)
{
s[k++]=(a[i]-'0'+c)%10;
c=(a[i]-'0'+c)/10;
}
else //如果b数长
for(;j>=0;j--)
{
s[k++]=(b[j]-'0'+c)%10;
c=(b[j]-'0'+c)/10;
}
if(c) //最后进位
s[k++]=c;
printf("\n#Case %d:\n%s + %s = ",count++,a,b);
for(k=k-1;k>=0;k--)
printf("%d",s[k]);
printf("\n");
}
return 0;
}
#include <stdio.h>
#include <string.h>
#define MAXLEN 1000
char a1[MAXLEN];
char a2[MAXLEN];
static int v1[MAXLEN];
static int v2[MAXLEN];
static int v3[MAXLEN];
int i,j,n,L,z;
void main(void) {
scanf("%d",&n);
for (j=0;j<n;j++) {
scanf("%s%s",a1,a2);
L=strlen(a1);
for (i=0;i<L;i++) v1[i]=a1[L-1-i]-'0';
L=strlen(a2);
for (i=0;i<L;i++) v2[i]=a2[L-1-i]-'0';
for (i=0;i<MAXLEN;i++) v3[i]=v1[i]+v2[i];
for (i=0;i<MAXLEN;i++) {
if (v3[i]>=10) {
v3[i+1]+=v3[i]/10;
v3[i]=v3[i]%10;
}
}
printf("Case %d:\n", j+1);
printf("%s + %s = ", a1, a2);
z=0;
for (i=MAXLEN-1;i>=0;i--) {
if (z==0) {
if (v3[i]!=0) {
printf("%d",v3[i]);
z=1;
}
} else {
printf("%d",v3[i]);
}
}
if (z==0) printf("0");
printf("\n");
}
}
//Sample Input
//3
//0 0
//1 2
//112233445566778899 998877665544332211
//
//Sample Output
//Case 1:
//0 + 0 = 0
//Case 2:
//1 + 2 = 3
//Case 3:
//112233445566778899 + 998877665544332211 = 1111111111111111110