求最大公约数,最小公倍数

输入两个正整数 m n,求其最大公约数和最小公倍数。

求最小公倍数算法:

最小公倍数 = 两整数的乘积 ÷ 最大公约数

根据求最小公倍数的算法,可以看出如果已知最大公约数,就能很容易求出最小公倍数。而通过辗转相除法和相减法,可以求得最大公约数,下面分别进行介绍。

代码如下:

cs 复制代码
#include<stdio.h>
int main()
{
    int m,n;//定义两个整数
    scanf("%d %d",&m,&n);
    int max,min;
    int a,b;//找出较小值a,较大值b
    a=m<n?m:n;//若m<n成立,则输出m,若不成立,则输出n
    b=m>n?m:n;//若m>n成立,则输出m,若不成立,则输出n
    for(int i=1;i<=a;i++)循环1到较小数范围内的数
    {
        if(a%i==0&&b%i==0)能被同时整除
        {
            max=i;最大公约数
        }
    }min=m*n/max;//最小公倍数
    printf("最大公约数是:%d\n最小公倍数是:%d", max, min);
    return 0;
}
相关推荐
洛水水14 小时前
【力扣100题】81.寻找两个正序数组的中位数
数据结构·算法·leetcode
石一峰69914 小时前
C 语言函数设计模式实战经验
c语言·开发语言·设计模式
happymaker062614 小时前
LeetCodeHot100——155.最小栈
算法
洛水水14 小时前
【力扣100题】85.每日温度
算法·leetcode·职场和发展
Coder-magician15 小时前
《代码随想录》刷题打卡day15:二叉树part05
数据结构·c++·算法
Kurisu_红莉栖15 小时前
力扣56合并区间
算法·leetcode
Irissgwe15 小时前
算法的时间复杂度和空间复杂度
数据结构·c++·算法·c·时间复杂度·空间复杂度
随意起个昵称15 小时前
区间dp-基础题目3(永别)
c++·算法
周末也要写八哥15 小时前
有向图Hierholzer算法的另一种实现
算法
bIo7lyA8v15 小时前
算法调优中的性能回归与基准测试分析的技术8
算法·数据挖掘·回归