您的位置:首页 > 其它

小学生算术

2015-12-08 21:13 127 查看


小学生算术

时间限制:3000 ms | 内存限制:65535 KB
难度:1

描述很多小学生在学习加法时,发现“进位”特别容易出错。你的任务是计算两个三位数在相加时需要多少次进位。你编制的程序应当可以连续处理多组数据,直到读到两个0(这是输入结束标记)。

输入输入两个正整数m,n.(m,n,都是三位数)
输出输出m,n,相加时需要进位多少次。
样例输入
123 456
555 555
123 594
0 0


样例输出
0
3
1


代码实现
#include <iostream>
using namespace std;
void dig(int a,int* x)
{
int i=0;
while(a>0)
{
x[i++]=a%10;
a=a/10;
}
}
int main()
{
int a,b,A[3],B[3];
while(cin>>a>>b)
{
if(a==0&&b==0)
break;
dig(a,A);
dig(b,B);
int c=0;
int count=0;
for(int i=0;i<3;i++)
{
int k=A[i]+B[i]+c;
if(k>=10)
count++;
c=k/10;
}
cout<<count<<endl;
}
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: