HDOJ_就这么个烂题总是WA先放这把

#include<stdio.h>
__int64 A[100]={0};
__int64 B[100]={0};
__int64 SUM[100]={0};
int main()
{int T ,i=0;
	__int64 a,b,sum;
	scanf("%d",&T);
	while (T--)
	{
		scanf("%I64d %I64d",&a,&b);
		sum=a+b;
		A[i]=a;
		B[i]=b;
		SUM[i]=sum;
		i++;
	}
	for(i=0;SUM[i]!=0;i++)
	{
		printf("Case %d:\n",i+1);
		printf("%I64d + %I64d = %I64d\n\n",A[i],B[i],SUM[i]);
	}
}

		

//--------正统
#include<stdio.h>
#include<string.h>
int shu(char a)
{
    return (a-'0');
}
int main(){
    char a[1000],b[1000];
    int num[1001];
    int n,i,j=1,al,bl,k,t;
	scanf("%d",&n);
    while(n--)
    {
       getchar();
        if(j!=1)
			printf("\n");
       scanf("%s",a);
       al=strlen(a);
       scanf("%s",b);
       bl=strlen(b);
       k=(al>bl)?al:bl;
       for(i=0;i<=k;i++)
       num[i]=0;
       t=k;
       for(k;al>0&&bl>0;k--)
       {
           num[k]+=shu(a[--al])+shu(b[--bl]);

           if(num[k]/10)
           {
               num[k-1]++;
               num[k]%=10;
           }
       }
       while(al>0)
       {
            num[k--]+=shu(a[--al]);
            if(num[k+1]/10)
           {
               num[k]++;
               num[k+1]%=10;
           }
       }
       while(bl>0)
       {
            num[k--]+=shu(b[--bl]);
            if(num[k+1]/10)
           {
               num[k]++;
               num[k+1]%=10;
           }
       }

       printf("Case %d:\n",j++);
       printf("%s + %s = ",a,b);
       for(i=0;i<=t;i++)
       {
           if(i==0&&num[i]==0)
           i++;
           printf("%d",num[i]);
       }
       printf("\n");
   }
   return 0;
}

posted @ 2014-04-11 11:28  夜歌乘年少  阅读(183)  评论(0编辑  收藏  举报