解题思路: 本题参考辗转相除法

两个整数的最大公约数是能够同时整除它们的最大的正整数。辗转相除法基于如下原理:两个整数的最大公约数等于其中较小的数和两数相除余数的最大公约数。

辗转相除的动画

Euclidean_algorithm_252_105_animation_flipped.gif

注意事项:
 if (m < n)
 {int temp = m;m = n;n = temp;}//交换m,n

此段代码不是必须的,因为m小于n, 在进行第一次辗转相除时,根据取模的特性, 如果m < n, k便会赋值给n,  根据这段代码while (k = m % n){m = n;n = k;}; 

m,n便会交换

但写了以上代码,可以减少一次循环。

参考代码:

#include 

int main()
{
    int m, n, k, sum;
    scanf("%d%d", &m, &n);
    sum = m * n;//sum保存m,n的乘积,便于我们接下来求最小公倍数


    if (m < n)
    {
        int temp = m;
        m = n;
        n = temp;
     }//交换m,n


    int x = gcd(n,m);

    printf("%d %d\n",x, sum/x);

    //int y =gcds(n,m);

    //printf("%d %d\n",y, sum/y);

}

//递归实现辗转相除

int gcd(int m, int n)
{
    return m%n ? gcd(n, m % n) : n; 
}


//普通循环实现辗转相除

int gcds(int m, int n)

{

    int k; 

    while (k = m % n)
    {
        m = n;
        n = k;
    }

    return n;

}


//曹茂麟纯棉内裤处对象送

点赞(1)
 

0.0分

2 人评分

C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:

一点编程也不会写的:零基础C语言学练课程

解决困扰你多年的C语言疑难杂症特性的C语言进阶课程

从零到写出一个爬虫的Python编程课程

只会语法写不出代码?手把手带你写100个编程真题的编程百练课程

信息学奥赛或C++选手的 必学C++课程

蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程

手把手讲解近五年真题的蓝桥杯辅导课程

评论列表 共有 0 条评论

暂无评论