1002答案杭电详解

 杭电1002答案详解:  

这道题的陷阱是无法用普通的int,long或double能完成的,涉及到了高精度的加法,关于具体的高精度问题,小编建议童鞋们拿出专门的时间把高精度问题整明白,小编在此给出这道题的解法

  具体的高精度加减乘除请参考小编整理的一个程序,请点击此链接链接

#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--)
    {
        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;
}

你可能感兴趣的:(c,算法,ACM,杭电,1002)