您的位置:首页 > 其它

小学生算术

2018-01-28 01:12 211 查看
小学生算术

时间限制: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;
}


下次一定要考虑前面注意细节哦~
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: