小学生算术
时间限制:3000 ms | 内存限制:65535 KB
难度:1
题目描述
很多小学生在学习加法时,发现“进位”特别容易出错。你的任务是计算两个三位数在相加时需要多少次进位。你编制的程序应当可以连续处理多组数据,直到读到两个0(这是输入结束标记)。
输入
输入两个正整数m,n.(m,n,都是三位数)
输出
输出m,n,相加时需要进位多少次。
样例输入
123 456
555 555
123 594
0 0
样例输出
0
3
1
解题思路
此题要求计算出要“进位”的次数,首先将输入的两个三位数m,n的个百千分离并分别用a1,b1,c1,a2,b2,c2表示。分别从个位相加判断,若大于等于10,则进一位x++,此时十位也加1。判断十位时,千位同理。
易错
若判断的个位大于等于10,十位忘记加1。我第一次做就错在这!!!
参考代码
#include<stdio.h>
int main()
{
int n,m,a1,b1,c1,a2,b2,c2,x;
while(~scanf("%d %d",&m,&n))
{
if(m==0&n==0)break;//若m,n为0,停止程序;
x=0;
a1=m%10;
b1=m%100/10;
c1=m/100;
a2=n%10;
b2=n%100/10;
c2=n/10;//分离各位;
if(a1+a2>=10)//分别判断;
x++;
b1++;
if(b1+b2>=10)
x++;
c1++;
if(c1+c2>=10)
x++;
printf("%d\n",x);
}
return 0;
}
下次一定要考虑前面注意细节哦~