码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 信息学奥赛一本通 1915:【01NOIP普及组】最大公约数与最小公倍数 | 洛谷 P1029 [NOIP2001 普及组] 最大公约数和最小公倍数问题


    【题目链接】

    ybt 1915:【01NOIP普及组】最大公约数与最小公倍数
    洛谷 P1029 [NOIP2001 普及组] 最大公约数和最小公倍数问题

    【题目考点】

    1. 最大公约数与最小公倍数

    • 求最大公约数的方法:见信息学奥赛一本通 1207:求最大公约数问题 | OpenJudge 2.2 7592:求最大公约数问题
    • 最大公约数与最小公倍数的关系:两数乘积为这两数最大公约数与最小公倍数的乘积

    【解题思路】

    已知两个正整数x,y。x是p,q两个数的最大公约数,y是p,q两个数的最小公倍数。
    因为两数乘积是最大公约数与最小公倍数的乘积,所以有: x y = p q xy = pq xy=pq
    p,q这两个数字,一定都大于等于最大公约数x,小于等于最小公倍数y。
    从x到y枚举p,通过 q = x y / p q = xy/p q=xy/p得到q。
    求出p,q的最大公约数,看最大公约数的值是否等于x。如果是,那么这一组p, q是满足条件的,做计数。否则不满足条件。
    最后输出满足条件的p, q的个数。

    【题解代码】

    解法1:使用迭代方法求最大公约数

    #include
    using namespace std;
    int gcd(int a, int b)//求a, b的最大公约数。注意必须满足a >= b
    {
        int r;
        while(b > 0)
        {
            r = a % b;
            a = b;
            b = r;
        }
        return a;
    }
    int main()
    {
        int x, y, p, q, ct = 0, x1;
        cin >> x >> y;
        for(p = x; p <= y; ++p)
        {
            if(x*y%p == 0)
            {
                q = x*y/p;
                x1 = gcd(p, q);//求出p, q的最大公约数x1 
                if(x1 == x)//如果与x相同,那么这一组p, q满足条件 
                    ct++;
            }
        }
        cout << ct;
        return 0;
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30

    解法2:使用递归方法求最大公约数

    #include
    using namespace std;
    int gcd(int a, int b)//求a, b的最大公约数。注意必须满足a >= b
    {
    	if(b == 0)
    		return a;
    	return gcd(b, a%b);
    }
    int main()
    {
        int x, y, p, q, ct = 0;
        cin >> x >> y;
        for(p = x; p <= y; ++p)
            if(x*y%p == 0 && gcd(p, x*y/p) == x) 
                ct++;
        cout << ct;
        return 0;
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
  • 相关阅读:
    Godot屏幕抖动效果原理与实现
    终于有人把数据架构讲明白了
    SpringBoot:整合监听器/过滤器和拦截器
    这几个小技巧,收藏起来总没错
    2022第十一届PMO大会(线上会议)成功召开
    java解析生成定时Cron表达式工具类
    自动控制系统实验总结
    今天告诉你界面控件DevExpress WinForms为何弃用经典视觉样式
    SpringBoot web静态资源映射
    Workflow,要不要了解一下
  • 原文地址:https://blog.csdn.net/lq1990717/article/details/126058494
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号