c语言输入三个数求最大公约数和最小公倍数,c语言编程 3、编写程序求出两个正整数的最大公约数与最小公倍数。其中最大公约数是能够整除这两个整...

本文展示了如何使用穷举法、欧几里得算法和递归算法来计算两个整数的最大公约数,并通过最大公约数求得它们的最小公倍数。在C语言中实现了这些算法,并在主函数中进行测试。

满意答案

00e27ab806e4881f8254fe7ae8741834.png

qsdk06615

2014.12.29

00e27ab806e4881f8254fe7ae8741834.png

采纳率:52%    等级:8

已帮助:509人

#include 

#include 

int exhaustion(int a, int b)    //采用穷举法计算最大公约数

{

int t = a;

if(b

t = b;

for(; t>0; t--)

{

if(a%t==0 && b%t==0)

break;

}

return t;

}

int Euclid(int a, int b)    //采用欧几里得算法求最大公约数

{

int t;

while(b!=0)

{

t = b;

b = a % b;

a = t;

}

return a;

}

int rec_gcd(int a, int b)   //采用递归算法求最大公约数

{

return b==0 ? a : rec_gcd(b, a%b);

}

int lcm_fun(int a, int b, int gcd)   //求两个数的最小公倍数

{

int t = a * b / gcd;

return t;

}

int main()

{

int x, y;

int gcd, lcm;

printf("请输入两个数并回车,中间以空格隔开:\n");

scanf("%d %d", &x, &y);

gcd = exhaustion(x, y);

printf("采用穷举法计算的最大公约数为:%d\n", gcd);

gcd = Euclid(x, y);

printf("采用欧几里德算法计算的最大公约数为:%d\n", gcd);

gcd = rec_gcd(x, y);

printf("采用递归算法计算的最大公约数为:%d\n", gcd);

lcm = lcm_fun(x, y, gcd);

printf("两数的最小公倍数为:%d\n", lcm);

return 0;

}

01分享举报

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值