python-leetcode-2427. 公因子的数目

2427. 公因子的数目 - 力扣(LeetCode)

要找两个正整数 ab公因子的数目,我们可以按照以下步骤来解决问题:


✅ 步骤说明:

  1. 求 a 和 b 的最大公约数(GCD)
    所有的公因子一定是 GCD 的因子。

  2. 统计 GCD 的因子个数
    枚举 1√GCD,找出能整除它的数,同时成对统计因子个数。


✏️ Python 示例代码:

import math

def common_factors(a: int, b: int) -> int:
    gcd = math.gcd(a, b)
    count = 0
    for i in range(1, int(gcd**0.5) + 1):
        if gcd % i == 0:
            count += 1  # i 是因子
            if i != gcd // i:
                count += 1  # gcd // i 是另一个因子
    return count

🔍 举个例子:

假设 a = 12b = 18

  • gcd(12, 18) = 6

  • 6 的因子是 1, 2, 3, 6

  • 所以返回值是 4

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值