算法 - 两数互质问题

[题目描述]

来源于某(忘记了)题库:

请问在1 到2020 中,有多少个数与2020 互质,即有多少个数与2020 的最大公约数为1。


尝试一:

一看这道题,……

么的思路啊!
  

可惜:


正文来了

看了看 大佬解法(忘记大佬连接了,抱歉),


/**
* 请问在 1 到 2020 中,有多少个数与 2020 互质,即有多少个数与 2020
* 的最大公约数为 1。(两个质数的判定)
*/
@Test
public void test13() {
    int count = 0;
    for (int i = 1; i <= 2020; i++) {
        if (getMaxNum(i, 2020) == 1) {
            count++;
            //System.out.println("i = " + i);
        }
    }
    System.out.println("count = " + count);
}

/**
* 这个函数是判断两个数是否为质数的函数;
* 这个方法绝了……
* return a % b == 0 ? b : getMaxNum(b, a % b);
* 返回 1 表示互质!否则视为不互质
*/
public int getMaxNum(int a, int b) {
    if (b == 0) return a;
    return getMaxNum(b, a % b);
}

关键在于求互质:
public int getMaxNum(int a, int b) {
if (b == 0) return a;
//return a % b == 0 ? b : getMaxNum(b, a % b);
return getMaxNum(b, a % b);
}

忘记了大佬连接,如有侵权请速联系我!抱歉!


最后,我要进大厂!加油奥里给!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

liusaisaiV1

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值