c语言求最小公倍数和最大公约数

注:最小公倍数等于两数相乘除以最大公约数

#include <stdio.h>

int LCM(int a,int b) //最小公倍数
{
    //两数相乘除以最大公约数
    int c = a*b;
    int d = GCD3(a,b);
    return c/d;
}

int GCD(int a,int b)//最大公约数
{
    //两种思路:  1.从1开始,找最大能整除这两个数的数
    //           2.从二者较小的数开始,直到有个数将二者整除
    int c = a<b?a:b;

    while ((a%c!=0)||(b%c!=0))
    {
        c--;
    }

    return c;
}

int GCD2(int a,int b)
{
    int c = a<b?a:b;
    int e=1;
    for(int d=1;d<=c;d++)
    {
        if((a%d==0)&&(b%d==0))
            e=d;
    }
    return e;

}

int GCD3(int a,int b) //辗转相除法:不断用除数除以余数,直到余数为0,最后的除数是最大公约数
{
    if(a>b)//取a小于等于b
    {
        a ^= b;
        b ^= a;
        a ^= b;
    }

    int c = b%a;
    while (c)
    {
        b = a;
        a = c;
        c = b%a;
    }
    return a;

}

int main(int argc, char *argv[])
{
    printf("%d\n",LCM(3,9));
    printf("Hello World!\n");
    return 0;
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值