最大公约数和最小公倍数-多语言

目录

[C 语言实现](#C 语言实现)

[Python 实现](#Python 实现)

[Java 实现](#Java 实现)

[Js 实现](#Js 实现)


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

程序分析:

  • 最小公倍数=输入的两个数之积除于它们的最大公约数,关键是求出最大公约数;

  • 求最大公约数用辗转相除法(又名欧几里德算法)

1、证明:设c是a和b的最大公约数,记为c=gcd(a,b),a>=b,

令r = a mod b

设a = kc,b = jc,则k,j互素,否则c不是最大公约数

据上,r = a-mb = kc-mjc = (k-mj)c

可知r也是c的倍数,且k-mj与j互素,否则与前述k,j互素矛盾,

由此可知,b与r的最大公约数也是c,即gcd(a,b) = gcd(b,a mod b),得证。

2、算法描述:

第一步:a ÷ b,令r为所得余数(0≤r 第二步:互换:置 a←b,b←r,并返回第一步。

C 语言实现

objectivec 复制代码
#include <stdio.h>

int main() {
    int a, b, t, r;

    // 提示用户输入两个数字
    printf("请输入两个数字:\n");
    scanf("%d %d", &a, &b);

    // 确保 a 是较大的数字
    if (a < b) {
        t = b;
        b = a;
        a = t;
    }

    // 计算 a 和 b 的乘积
    int n = a * b;

    // 使用辗转相除法计算最大公约数
    r = a % b;
    while (r != 0) {
        a = b;
        b = r;
        r = a % b;
    }

    // 输出结果
    printf("这两个数的最大公约数是 %d,最小公倍数是 %d\n", b, n / b);

    return 0; // 返回0表示程序正常结束
}
  1. 头文件 :包含标准输入输出库 #include <stdio.h>
  2. 主函数int main() 是程序的入口点。
  3. 输入 :使用 scanf 获取用户输入的两个整数 ab
  4. 确保 a 是较大的数字 :如果 a 小于 b,则交换它们的值。
  5. 计算乘积 :计算 ab 的乘积并存储在 n 中。
  6. 计算最大公约数:使用辗转相除法(欧几里得算法)计算最大公约数。
  7. 输出结果 :使用 printf 输出最大公约数和最小公倍数(通过 n / b 计算)。
  8. 返回值return 0; 表示程序正常结束。

这种实现方式清晰易懂,能够正确计算并输出两个数字的最大公约数和最小公倍数。

Python 实现

python 复制代码
def main():
    # 提示用户输入两个数字
    a, b = map(int, input("请输入两个数字:\n").split())

    # 确保 a 是较大的数字
    if a < b:
        a, b = b, a

    # 计算 a 和 b 的乘积
    n = a * b

    # 使用辗转相除法计算最大公约数
    r = a % b
    while r != 0:
        a, b = b, r
        r = a % b

    # 输出结果
    print(f"这两个数的最大公约数是 {b},最小公倍数是 {n // b}")

if __name__ == "__main__":
    main()  # 调用主函数
  • 使用 input() 函数获取用户输入,并使用 map()split() 将输入的字符串转换为两个整数。
  • 通过条件判断确保 a 是较大的数字。
  • 计算两个数字的乘积 n
  • 使用辗转相除法计算最大公约数。
  • 最后输出最大公约数和最小公倍数

Java 实现

java 复制代码
import java.util.Scanner;

public class GCDAndLCM {
    public static void main(String[] args) {
        Scanner scanner = new Scanner(System.in);

        // 提示用户输入两个数字
        System.out.println("请输入两个数字:");
        int a = scanner.nextInt();
        int b = scanner.nextInt();

        // 确保 a 是较大的数字
        if (a < b) {
            int t = b;
            b = a;
            a = t;
        }

        // 计算 a 和 b 的乘积
        int n = a * b;

        // 使用辗转相除法计算最大公约数
        int r = a % b;
        while (r != 0) {
            a = b;
            b = r;
            r = a % b;
        }

        // 输出结果
        System.out.printf("这两个数的最大公约数是 %d,最小公倍数是 %d\n", b, n / b);

        scanner.close(); // 关闭扫描器
    }
}
  1. 使用 Scanner 类获取用户输入。
  2. 提示用户输入两个数字,并将其存储在变量 ab 中。
  3. 通过条件判断确保 a 是较大的数字。
  4. 计算两个数字的乘积 n
  5. 使用辗转相除法计算最大公约数。
  6. 最后输出最大公约数和最小公倍数。
  7. 关闭 Scanner 以释放资源。

Js 实现

javascript 复制代码
function calculateGCDAndLCM() {
    // 提示用户输入两个数字
    const a = parseInt(prompt("请输入第一个数字:"));
    const b = parseInt(prompt("请输入第二个数字:"));

    // 确保 a 是较大的数字
    let larger = Math.max(a, b);
    let smaller = Math.min(a, b);

    // 计算 a 和 b 的乘积
    const n = larger * smaller;

    // 使用辗转相除法计算最大公约数
    let r = larger % smaller;
    while (r !== 0) {
        larger = smaller;
        smaller = r;
        r = larger % smaller;
    }

    // 输出结果
    alert(`这两个数的最大公约数是 ${smaller},最小公倍数是 ${n / smaller}`);
}

// 调用函数
calculateGCDAndLCM();
  1. 使用 prompt() 函数获取用户输入,并将输入的字符串转换为整数。
  2. 使用 Math.max()Math.min() 确保 larger 是较大的数字,smaller 是较小的数字。
  3. 计算两个数字的乘积 n
  4. 使用辗转相除法计算最大公约数。
  5. 最后使用 alert() 输出最大公约数和最小公倍数。

注意:

  • 该代码在浏览器环境中运行,因为它使用了 prompt()alert() 函数来与用户交互。
相关推荐
MiyamiKK572 分钟前
leetcode_字符串 409. 最长回文串
数据结构·算法·leetcode
Biomamba生信基地2 分钟前
R语言基础| 回归分析
开发语言·回归·r语言
姓学名生6 分钟前
李沐vscode配置+github管理+FFmpeg视频搬运+百度API添加翻译字幕
vscode·python·深度学习·ffmpeg·github·视频
黑客-雨16 分钟前
从零开始:如何用Python训练一个AI模型(超详细教程)非常详细收藏我这一篇就够了!
开发语言·人工智能·python·大模型·ai产品经理·大模型学习·大模型入门
Pandaconda21 分钟前
【Golang 面试题】每日 3 题(三十九)
开发语言·经验分享·笔记·后端·面试·golang·go
半盏茶香22 分钟前
扬帆数据结构算法之雅舟航程,漫步C++幽谷——LeetCode刷题之移除链表元素、反转链表、找中间节点、合并有序链表、链表的回文结构
数据结构·c++·算法
是梦终空24 分钟前
JAVA毕业设计210—基于Java+Springboot+vue3的中国历史文化街区管理系统(源代码+数据库)
java·spring boot·vue·毕业设计·课程设计·历史文化街区管理·景区管理
加油,旭杏25 分钟前
【go语言】变量和常量
服务器·开发语言·golang
行路见知25 分钟前
3.3 Go 返回值详解
开发语言·golang
xcLeigh29 分钟前
WPF实战案例 | C# WPF实现大学选课系统
开发语言·c#·wpf