代码有什么问题吗
题目描述很多小学生在学习加法时,发现“进位”特别容易出错。你的任务是计算两个正整数在相加时有多少次进位。你编制的程序可以连续处理多组数据,直到输入两个0(这是输入结束标记)
输入描述
输入文件中,每行上有两个正整数x,y
,中间用一个空格隔开,最后一行是0 0。
输出描述
输出文件对于每行数据输出一行,每行只有一个整数,表示x,y
相加时有多少次进位。
样例
输入 复制
123 4567
555 555
123 594
0 0
输出 复制
1
3
1
提示
【数据范围】
50%的数据,0<x,y≤10000
100%的数据,0<x,y≤1000000000
100%的数据,n≤10000
#include<bits/stdc++.h>
using namespace std;
int main()
{
long long x,y,t,s=0;
while(1){
s=0;
cin>> x>>y;
if(x==0&&y==0) return 0;
if(x>y){
t=x;x=y;y=t;
}
while(x>0)
{
t=x%10+y%10;
x=x/10;y=y/10;
if(t>9) {s++;x++;}
}
cout<<s<<endl;
}
} 代码存在一个问题,即在计算进位时,当两个数字的个位相加大于9时,只将x加1,而没有将y加1。这会导致在计算进位时,只考虑了一个数字的进位情况,而没有考虑到另一个数字的进位情况。
以下是修改后的代码:
#include <iostream>
using namespace std;
int main()
{
long long x, y, t, s = 0;
while (1)
{
s = 0;
cin >> x >> y;
if (x == 0 && y == 0)
return 0;
if (x > y)
{
t = x;
x = y;
y = t;
}
while (x > 0)
{
t = x % 10 + y % 10;
x = x / 10;
y = y / 10;
if (t > 9)
{
s++;
y++; // 将y加1,考虑另一个数字的进位情况
}
}
cout << s << endl;
}
return 0;
}
在原代码的基础上,增加了 y++ 这一行,当两个数字的个位相加大于9时,同时将y加1,以考虑另一个数字的进位情况。这样就能正确地计算出两个数字相加时的进位次数。
页:
[1]