P1029 最大公约数和最小公倍数问题

这篇具有很好参考价值的文章主要介绍了P1029 最大公约数和最小公倍数问题。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

3 2 1 上题目链接:
P1029 [NOIP2001 普及组] 最大公约数和最小公倍数问题

本小蒟蒻的原始思路就是枚举所有范围内的数,分别求出他们的最大公约数和最小公倍数,再看是否满足题意。

于是就有了以下一言难尽的东西(;′⌒`)↓

#include <stdio.h>

int main()
{
    int x,y,count;
    scanf("%d%d",&x,&y);
    for(int i=x;i<=y;i+=x)//i+=x是因为求出来的数肯定是x的倍数,所以就以x为增量了
    {
        for(int j=x;j<=y;j+=x)
        {
            int m=i,n=j,t;
            while(m%n)//求最大公约数
            {
                t=m%n;
                m=n;
                n=t;
            }
            if(n==x&&i*j==x*y)//i*j==x*y是因为最小公倍数等于两个数的乘积除以最大公约数
                count++;
        }
    }
    printf("%d",count);
    return 0;
}

皇天不负有心人,收到了2个TLE,其他全WA

自我反省大佬们的题解,做了以下优化↓

#include <stdio.h>
#include <math.h>

int main()
{
    int x,y,count=0;
    scanf("%d%d",&x,&y);
    if(x==y)//特解
        count--;
    for(int i=x;i<=sqrt(x*y);i+=x)//减少循环次数
    {
        for(int j=x;j<=y;j+=x)
        {
            int m=i,n=j,t;
            while(m%n)
            {
                t=m%n;
                m=n;
                n=t;
            }
            if(n==x&&i*j==x*y)
                count+=2;//每次加2,因为i和j倒过来又是一种情况
        }
    }
    printf("%d",count);
    return 0;
}

注:

  1. 补充上遗漏的特解(不然也会错),x=y时,只会出现一次
  2. x=y时,i=j=x=y,在此之后就都是倒过来重复的情况,所以循环到√(x*y)即可,减少了循环次数
  3. 综上,count每次+2,特解时count-1即可

不知道为什么就能AC了,有大佬说需要用long long,不然会爆,但我没有(⊙o⊙)?

觉得还有一个方法很好,递归辗转相除求最大公约数:文章来源地址https://www.toymoban.com/news/detail-825019.html

int gcd(int n,int m)
{
    if(n%m==0)
	return m;
    else 
	return gcd(m,n%m);
}

到了这里,关于P1029 最大公约数和最小公倍数问题的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 【Python 随练】求最大公约数和最小公倍数

    输入两个正整数 m 和 n,求其最大公约数和最小公倍数。 在本篇博客中,我们将解决一个常见的数学问题:求两个正整数的最大公约数和最小公倍数。我们将提供问题的解析,并给出一个完整的代码示例来计算最大公约数和最小公倍数。 给定两个正整数m和n,我们需要求它们

    2024年02月09日
    浏览(71)
  • 【C语言】求最大公约数和最小公倍数

    方法一:利用 定义法 求最大公因数和最小公倍数 方法二:最小公倍数求法同上, 最大公约数方法不同 方法一方法二的结果示例如下   方法三:利用 辗转相除法 求最大公约数和最小公倍数 法(1)结果示例如下:  法(2)示例结果如下:  以上就是用C语言循环和循环之前的

    2024年02月07日
    浏览(53)
  • C++求最大公约数和最小公倍数的方法

    每次遇到最大公约数和最小公倍数时总是忘记,这里总结了两种求最大公约数和最小公倍数的方法。 欧几里得算法是求解两个数的最大公约数的一种常用方法。该算法基于以下原理:两个整数的最大公约数等于其中较小数和两数的余数之间的最大公约数。可以通过递归调用该

    2024年02月15日
    浏览(44)
  • 【C语言】两个整数最大公约数和最小公倍数

    输入两个整数,求这两个数的最大公约数和最小公倍数。 第一种求法(辗转相除法)这个方法代码较洁简,我也比较推荐就是刚开始有点比较难了解。 首先,来看看怎么求最大公约数,求最大公约数需要用到 欧几里得算法 ,也称为辗转相除法。算法就是用两数中较大的数

    2024年02月04日
    浏览(46)
  • 求其最大公约数和最小公倍数,一行代码完成

    题目:输入两个正整数 m 和 n,求其最大公约数和最小公倍数。 求出最大公约数就行,最小公倍数用m*n除以最大公约数就行

    2024年02月05日
    浏览(61)
  • 左手Python 右手R —— 最大公约数和最小公倍数

      此专栏为python与R语言对比学习的文章;以通俗易懂的小实验,带领大家深入浅出的理解两种语言的基本语法,并用以实际场景!感谢大家的关注,希望对大家有所帮助。   “博观而约取,厚积而薄发!”谨以此言,望诸君共勉   本文针对数学问题“ 最大公约数、最

    2023年04月21日
    浏览(47)
  • 【c语言】—求最大公约数和最小公倍数多种方法

    目录 一.求最大公约数 1.枚举法求最大公约数 2.辗转相除法 二.求最小公倍数 1.枚举法求最小公倍数 2.简易法 3.公式法 思路:先求两个数中的最小值,最大公约数不可能大于两个数的最小数 比如6和18,最大公约数就是6 再如3和9,最大公约数就是3 然后再从1开始循环遍历到最小

    2024年02月08日
    浏览(59)
  • 【C语言】一篇博客带你弄懂最大公约数和最小公倍数

    我们在C语言的学习中,经常会遇到这样一些数学题目,良好掌握这些题目有利于我们理解和学习C语言,话不多说,直接进入主题 最大公约数: 首先我们举个例子,比如12 和16,12的约数有(1,2 ,3,4,6,12),16的约数有(1,2,4,8,16)公约数就是两个数共同的约数,(1,2,4)而公约数

    2024年02月04日
    浏览(48)
  • 输入两个正整数,求这两个正整数的最大公约数和最小公倍数。

    一、输入两个正整数,求这两个正整数的最大公约数和最小公倍数。         最大公约数:1、这个数同时能被两个整数整除,余数为0 就是公约数                               2、只要在公约数中取最大值即可         最小公倍数:1、这个数能同时整除两个正整数    

    2024年02月06日
    浏览(53)
  • C语言——输入两个正整数m和n,求其最大公约数和最小公倍数

    目录 1.最大公约数求法 1.1辗转相除法 1.2相减法 2.最小公倍数求法 3.代码实现 4.结果展示 1.1辗转相除法 设有两整数a和b: a%b得余数c 若c==0,则b即为两数的最大公约数 若c!=0,则a=b,b=c,再回去执行第一步。 例如:求27和15的最大公约数过程为: 27÷15 余12 15÷12 余3 12÷3 余0 因

    2024年02月01日
    浏览(43)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包