(44)公因子的数目

文章目录


每日一言

懒惰行动得如此缓慢,贫穷很快就能超过它。------富兰克林


题目

题目链接:公因子的数目

给你两个正整数 a 和 b ,返回 a 和 b 的 公 因子的数目。

如果 x 可以同时整除 a 和 b ,则认为 x 是 a 和 b 的一个 公因子 。

  • 示例 1:

    输入:a = 12, b = 6

    输出:4

    解释:12 和 6 的公因子是 1、2、3、6 。

  • 示例 2:

    输入:a = 25, b = 30

    输出:2

    解释:25 和 30 的公因子是 1、5 。

提示:

1 <= a, b <= 1000


解题思路

法一:

暴力解法,两数的最大公因子一定小于等于他们中最小的数,

接下来只要从1~a(假设它最小)遍历每一个数字,寻找满足条件的数,让计数变量加一,最后返回计数变量

法二:

先计算两数的最大公约数m,m的公因子个数就是两数的公因子个数

代码

法一:

c 复制代码
int commonFactors(int a, int b) {
    int count = 0;//计数
    int i = a<b?a:b;//
    
    while(i>=1)
    {
        if(a%i == 0 && b%i == 0)
            count++;
        i--;
    }
    return count;
}

法二:

c 复制代码
//计算最大公约数
int gcd(int x,int y)
{
    //递归
    return y==0?x:gcd(y,x%y);
}

int commonFactors(int a, int b) {
    int m = gcd(a,b);//求最大公约数

    int count = 0;//计数
    int i = 0;
    for(i=1;i*i<=m;i++)
    {
        //i是m的因子,i就是两数的公因子
        if(m%i==0)
        {
            count++;

            //如果i*i!=m,则m/i(与i不相等)
            //也可以做m的因子
            if(i*i!=m)
                count++;
        }

    }
    return count;
}

结语

请给自己些耐心,一口吃不成胖子。
山外青山楼外楼,莫把百尺当尽头。
保持空杯心态加油努力吧!


都看到这里啦!真棒(*^▽^*)

可以给作者一个免费的赞赞吗,这将会鼓励我继续创作,谢谢大家

编程小白写作,如有纰漏或错误,欢迎指正


相关推荐
zhangfeng11331 小时前
算子开发 Overwrite 覆盖/替换模式 Accumulate 累加模式,性能对比 memset错误 bat_alloc 错误
c语言·人工智能·gnu·算子开发
SuperByteMaster1 小时前
JLinkDevices.xml FLM文件路径不对
c语言
Go-higher1 小时前
DriverTest 驾考知识卡片学习助手 —— 一款基于 Jetpack Compose 的现代 Android 学习APP
android·学习
星幻元宇VR1 小时前
公共安全主题展厅设备【防洪防汛安全科普系统】
科技·学习·安全
LDR0062 小时前
LDR6500赋能POS机底座:单口Type-C供电、维护与产测一体化解决方案
大数据·c语言·人工智能
AI科技星2 小时前
32维超复数流形中意识信息场与物质耦合的拓扑动力学
人工智能·学习·算法·数据挖掘·回归·乖乖数学·全域数学
鱼很腾apoc2 小时前
【Linux】第7期 进程间通信 (IPC) 详解:管道 (匿名 / 命名) + System V
linux·服务器·c语言·学习·进程间通信·ipc
科技大视界3 小时前
大学生专业课笔记本用哪款?来酷Air14酷睿版14英寸轻薄笔记本电脑适合学习任务多的人
学习
weixin_423533993 小时前
c++类的继承学习-去中心化交易所(DEX)的“流动性池初始化与交易指令”设计
c++·学习·去中心化
远离UE43 小时前
UE5 各类型灯光学习
学习·ue5