还是A+B
Time Limit : 2000/1000ms (Java/Other) Memory Limit : 65536/32768K (Java/Other)
读入两个小于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
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; }