且构网

分享程序员开发的那些事...
且构网 - 分享程序员编程开发的那些事

HDU1229 还是A+B

更新时间:2021-08-15 21:30:25

还是A+B
Time Limit : 2000/1000ms (Java/Other)   Memory Limit : 65536/32768K (Java/Other)

Total Submission(s) : 5   Accepted Submission(s) : 3

Problem Description
读入两个小于10000的正整数A和B,计算A+B。需要注意的是:如果A和B的末尾K(不超过8)位数字相同,请直接输出-1。
 
Input
测试输入包含若干测试用例,每个测试用例占一行,格式为"A B K",相邻两数字有一个空格间隔。当A和B同时为0时输入结束,相应的结果不要输出。
 
Output
对每个测试用例输出1行,即A+B的值或者是-1。

Sample Input
1 2 1
11 21 1
108 8 2
36 64 3
0 0 1
 
Sample Output
3
-1
-1

100

#include<stdio.h>
int a[2000];
int b[2000];
int main()
{
    int i,j,n,m,k,flag1,flag2,x1,x2,v1,v2,count;
    while(scanf("%d %d %d",&n,&m,&k),n!=0&&m!=0)
    {
        x1=n,x2=m;flag1=0,flag2=0;
        count=k;v1=0,v2=0;
        while(count--)
        {
           a[v1++]=x1%10;
           b[v2++]=x2%10;
           x1/=10,x2/=10;
        }
        for(i=v1-1;i>=0;i--)
        {
           flag1=flag1*10+a[i];
           flag2=flag2*10+b[i];
        }
        if(flag1!=flag2)
        printf("%d\n",n+m);
        else
        printf("-1\n");
    }
    return 0;
}