C语言求两个数m、n的最大公约数。(带注释)

 我来答
南宫昆颉皋诺
2020-05-17 · TA获得超过3万个赞
知道大有可为答主
回答量:1.2万
采纳率:33%
帮助的人:831万
展开全部
<1>
用辗转相除法(欧几里德法)求最大公约数
算法描述:
m用n求余为a,
若a不等于0

m
=
n,
n
=
a,
继续求余
否则(即若a为0)
n
为最大公约数
gcd(int
a,
int
b)
{
int
t;
if
(a
<
b)
t=a,a=b,b=t;
if
(b
==
0)
return
a;
else
t=
a%b;
while
(t!=
0)
{
a=b;
b=t;
t=a%b;
}
return
b;
}
main()
{
int
a,b;
printf("输入两个数字:");
scanf("%d%d",&a,&b);
printf("%d\n",gcd(a,b));
}
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
丹泰清闫旭
2020-05-18 · TA获得超过3.1万个赞
知道大有可为答主
回答量:1.2万
采纳率:26%
帮助的人:588万
展开全部
不是

辗转相除


可以参考
下面

程序
void
main()
{
int
m,n,a,b,i;
scanf("%d%d",&m,&n);
i=m<n?m:n;
//返回m,n中较小的值
do
{
if(m%i==0
&&
n%i==0)
{
a=i;
//求出最大公约数
break;
}
}while(i--);
b=m*n/a;
//求出最小公倍数
printf("%d,%d",a,b);
}
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式