HDU1229 还是A+B
还是A+BTime 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;
}
最后更新:2017-04-03 12:54:47