求最大公约数

最大公约数:Greatest Common Divisor(GCD)

基本概念:多个整数共有约数中最大的一个

图例:

方法一:循环相减求最大公约数

流程图:

代码实现: 


import java.util.Scanner;

/**
 * 键盘录入两个不一样的整数求取其最大公约数      1.循环相减求最大公约数
 * @author buyi杨
 */
public class Test15 {
    public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);
        System.out.println("请输入第一个整数");
        int num1 = sc.nextInt();
        System.out.println("请输入第二个整数");
        int num2 = sc.nextInt();
        while (num1 != num2) {
            if (num1 > num2) {
                num1 = num1 - num2;
            }
            if (num1 < num2) {
                num2 = num2 - num1;
            }

        }

        System.out.println("最大公约数是:" + num1);
    }
}

 方法二:循环相模(欧几里得算法)求最大公约数

流程图:

 

 代码实现:

import java.util.Scanner;

/**
 * 键盘录入两个不一样的整数求取其最大公约数    2.循环相模求最大公约数
 *
 * @author buyi杨
 */
public class Test16 {
    public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);
        System.out.println("请输入第一个整数");
        int num1 = sc.nextInt();
        System.out.println("请输入第二个整数");
        int num2 = sc.nextInt();
        if (num1 >= num2) {
            while (num1 % num2 !=0) {
                int num3 = num1 % num2;
                num1 = num2;
                num2 = num3;
            }
            System.out.println("最大公因数:" + num2);
        } else {
            while ( num2 % num1 !=0) {
                int num3 = num2 % num1;
                num2 = num1;
                num1 = num3;
            }
            System.out.println("最大公因数:" + num1);
        }
    }
}

方法三:循环检测(穷举法)求最大公约数

流程图:

 

代码实现:

import java.util.Scanner;

/**
 * 键盘录入两个不一样的整数求取其最大公约数    2.循环检测求最大公约数
 * @author buyi杨
 */
public class Test17 {
    public static void main(String[] args) {
        Scanner sc =new Scanner(System.in);
        System.out.println("请输入第一个整数");
        int num1 = sc.nextInt();
        System.out.println("请输入第二个整数");
        int num2 = sc.nextInt();
        int temp = 0;
        for (temp = num1 ; ;temp--){
            if (num1 % temp == 0 && num2 %temp == 0) {
                break;
            }
        }
        System.out.println("最大公约数:" + temp);
    }
}

留言:以上是本新人小白所作,如有问题或建议欢迎留言哦 ,喔!

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值