#include
int main(){
int a,b,temp,s1,s2,z;
scanf("%d %d",&a,&b);
if(a<b){
temp=a;
a=b;
b=temp;
}
s1=a;
s2=b;
while(b!=0){
temp=s1%s2;
s1=s2;
s2=temp;
}
z=a*b/s2;
printf("%d %d",s2,z);
}
C++求最大公约最小公倍数以下代码运行被终止,请问问题出在哪里?
- 写回答
- 好问题 0 提建议
- 关注问题
- 邀请回答
-
6条回答 默认 最新
- 若雪如风 2017-06-03 16:34关注
#include //要包含头文件
int main(){
int a,b,temp,s1,s2,z;
scanf("%d %d",&a,&b);
if(a<b){
temp=a;
a=b;
b=temp;
}
s1=a;
s2=b;
while(s2!=0){ //b改为s2,不然死循环
temp=s1%s2;
s1=s2;
s2=temp;
}
z=a*b/s2; //退出循环时,s2为0,除零错误
printf("%d %d",s2,s1); //s1即为最大公约数
return 0; //要有返回值
}本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 无用评论 打赏 举报