题目链接:
http://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&page=show_problem&category=&problem=976&mosmsg=Submission+received+with+ID+11932248
Problem B: Primary Arithmetic
Input
Each line of input contains two unsigned integers less than 10 digits. The last line of input contains 0 0.Output
For each line of input except the last you should compute and print the number of carry operations thatwould result from adding the two numbers, in the formatshown below.Sample Input
123 456 555 555 123 594 0 0
Sample Output
No carry operation. 3 carry operations. 1 carry operation.
当答案为1 和大于1时,输出时不同的。。。。
#include <iostream>
#include <cstdio>
using namespace std;
int main()
{
unsigned int a,b,c,ans;
while(cin>>a>>b){
if(a==0&&b==0)
break;
c=ans=0;
while(a!=0 || b!=0 ){
c+=a%10 + b%10;
a/=10;
b/=10;
if(c>9){
ans++;
}
c/=10;
}
if(ans==0)
cout<<"No carry operation."<<endl;
else if(ans==1)
cout<<"1 carry operation.\n";
else
printf("%d carry operations.\n",ans);
}
}
本文探讨了在进行多位数相加时如何计算进位操作的数量,为教育评估提供依据。
380

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



