-
题目描述:
-
读入两个小于10000的正整数A和B,计算A+B。需要注意的是:如果A和B的末尾K(不超过8)位数字相同,请直接输出-1。
-
输入:
-
测试输入包含若干测试用例,每个测试用例占一行,格式为"A B K",相邻两数字有一个空格间隔。当A和B同时为0时输入结束,相应的结果不要输出。
-
输出:
-
对每个测试用例输出1行,即A+B的值或者是-1。
-
样例输入:
-
1 2 1 11 21 1 108 8 2 36 64 3 0 0 1
-
样例输出:
-
3 -1 -1 100
最近做的几题都没什么难度,题目意思简单明了,请允许我每次做都挑简单的水题先做。。这道题的意思是,如果两个数末K位的值都相同,则输出-1,否则输出两个数的和。具体实现的时候,只要不断地比较后面的最末位数是否相同即可,不断的求模,取余。即使是个位数,K为4的话,也没事,默认前几位都为0。
#include <iostream> using namespace std; int main(){ int a,b,k; while(cin>>a>>b>>k){ if(a == 0 && b == 0) break; int result; result = a + b; bool flag = true; for(int i=0;i<k;i++){ int a_value = a % 10; a = a/10; int b_value = b % 10; b = b/10; if(a_value == b_value) continue; else{ flag = false; break; } } if(flag) cout<<-1<<endl; else cout<<result<<endl; } return 0; }

本题要求读入两个小于10000的正整数A和B,如果A和B的末尾K位数字相同则输出-1;否则输出A+B的值。通过不断比较最末位数来实现。
1651

被折叠的 条评论
为什么被折叠?



