【数论】最大公约数、约数的个数与约数之和定理

简介: 先来科普下什么是约数:当a能被b整除,我们就说b为a的约数,b的倍数为a

Halo,这里是Ppeua。平时主要更新C语言,C++,数据结构算法......感兴趣就关注我吧!你定不会失望。


🌈个人主页:主页链接


🌈算法专栏:专栏链接


    我会一直往里填充内容哒!


🌈LeetCode专栏:专栏链接


目前在刷初级算法的LeetBook 。若每日一题当中有力所能及的题目,也会当天做完发出


🌈代码仓库:Gitee链接


🌈点击关注=收获更多优质内容🌈


df1b33904c294d2ca9d169e723a52b1a.jpg


用辗转相除法求最大公约数,以及数论相关的知识:约数个数与约数和的定理,及代码实现

 

先来科普下什么是约数:当a能被b整除,我们就说b为a的约数,b的倍数为a


题目:最大公约数


4066e5d6b4bf45159813bbbd682e0306.png



题解:


这里我们用到了辗转相除法 先读入a与b这两个数,之后把a与b相除,令其结果为c,若c不为0,则令a=b,b=c(辗转就是体现在了这里),若c为0,则说明b为a的最大公约数,则输出b即可


671f3cbf7e194942975b367e98d9ac8f.jpg


代码实现:


#include<iostream>
using namespace std;
int gcd(int a,int b)
{
    return b?gcd(b,a%b):a;
}
int main()
{
    int n=0;
    cin>>n;
    while(n--)
    {
        int a,b;
        cin>>a>>b;
        cout<<gcd(a,b)<<endl;
    }
    return 0;
}


题目:约数个数


60b9aef908f345fc98b1253842a3129d.png


题解:


这里先科普一个数学知识,约数个数定理,假设这个数为16,求出他的质因子为2,其指数为4


那么其约数的个数就为指数加一(4+1)


可以这样理解

第一个约数为其因子的1次方2,第二个约数为其因子的二次方2*2

第三个约数为其因子的三次方2*2*2

第四个约数为其因子的四次方2*2*2*2  第五个约数为其因子的0次方也就是1


d8f2a76a4c5d4ac2893b5be7d3e3775b.jpg



再举一个例子:


所以360的约数个数就为(3+1)*(2+1)*(1+1)


这就是约数个数定理

回顾一下 我们要做的就是将一个数求出他每一个质因子(不会的uu们可以看看这篇文章分解质因数)并记录其指数情况。之后将指数拿出来做乘法就ok了

54d1f7860d8b46be96c2174b663b23a2.jpg

这里用hash表记录其质因子与指数的情况,其中key为质因子 value为指数,所以最后的表达式就为指数value,所以最后就将其加一再相乘即可。


代码实现:


#include<iostream>
#include<unordered_map>
using namespace std;
const int N=1e9+7;
int main()
{
    unordered_map<int,int>map;
    int n=0,s;
    cin>>s;
    while(s--)
    {
      cin>>n;
     for(int i=2;i<=n/i;i++)
    {
        while(n%i==0)
        {
            n/=i;
            map[i]++;
        }
    }
     if(n>1)map[n]++;
    }
    long long res=1;
    for(auto ma:map)
    {
        long long p=1;int a=ma.second;
        res=(res*(a+1))%N;
    }
    cout<<res;
}


题目:约数之和


a02770e21c9c41fdb9ba70705bd78333.png


题解:


上面学了约数个数的定理,现在我们再来学一下约数之和定理,同样非常的简单


仍然以16来举例子,其质因子为2指数为4.


所以其约数之和为(2^0+2^1+2^2+2^3+2^4)=31


再来举上面360的例子:


7ac951e2f9ee4d60adad64fe3f2bbd5f.jpg



所以其约数之和为1261


这就是约数之和定理。

回顾一下 我们要做的就是将一个数求出他每一个质因子(不会的uu们可以看看这篇文章分解质因数)并记录其指数情况。之后将其拿出来先相加再做乘法就ok了

这里用hash表记录其质因子与指数的情况,其中key为质因子 value为指数,所以最后的表达式就为指数value与其质因子,先相加再相乘就好。


代码实现:


#include<iostream>
#include<unordered_map>
using namespace std;
const int N=1e9+7;
int main()
{
    unordered_map<int,int>map;
    int n=0,s;
    cin>>s;
    while(s--)
    {
      cin>>n;
     for(int i=2;i<=n/i;i++)
    {
        while(n%i==0)
        {
            n/=i;
            map[i]++;
        }
    }
     if(n>1)map[n]++;
    }
    long long res=1;
    for(auto ma:map)
    {
        long long p=1;int a=ma.second;
        while(a--)p=(p*ma.first+1)%N;
        res=res*p%N;
    }
    cout<<res;
}


完结撒花:


🌈本篇博客的内容【数论:最大公约数、约数的个数与约数之和定理】已经结束。

🌈若对你有些许帮助,可以点赞、关注、评论支持下博主,你的支持将是我前进路上最大的动力。


🌈若以上内容有任何问题,欢迎在评论区指出。若对以上内容有任何不解,都可私信评论询问。


🌈诸君,山顶见!

ppeua
+关注
目录
打赏
0
0
0
0
10
分享
相关文章
【Shell 命令集合 磁盘维护 】Linux 设置和查看硬盘驱动器参数 hdparm命令使用教程
【Shell 命令集合 磁盘维护 】Linux 设置和查看硬盘驱动器参数 hdparm命令使用教程
353 0
【Windows 逆向】OD 调试器工具 ( 推荐汉化版的 OD 调试工具 | 吾爱破解专用版Ollydbg | 备选工具 )
【Windows 逆向】OD 调试器工具 ( 推荐汉化版的 OD 调试工具 | 吾爱破解专用版Ollydbg | 备选工具 )
9916 0
【Windows 逆向】OD 调试器工具 ( 推荐汉化版的 OD 调试工具 | 吾爱破解专用版Ollydbg | 备选工具 )
|
8月前
|
【C++】二叉搜索树(BST)
二叉搜索树(Binary Search Tree, BST)是一种特殊的二叉树,其每个节点的左子树所有节点值小于该节点值,右子树所有节点值大于该节点值,且左右子树也均为二叉搜索树。BST支持高效的数据查找、插入和删除操作,时间复杂度通常为O(log n)。本文档详细介绍了BST的基本概念、存储结构及其实现,包括迭代和递归两种方式的查找、插入、删除等操作的具体代码示例。
136 3
React 分页组件 Pagination
本文介绍了如何在 React 中从零构建分页组件,涵盖基础概念、常见问题及解决方案。通过示例代码详细讲解了分页按钮的创建、分页按钮过多、初始加载慢、状态管理混乱等常见问题的解决方法,以及如何避免边界条件、性能优化和用户反馈等方面的易错点。旨在帮助开发者更好地理解和掌握 React 分页组件的开发技巧,提升应用的性能和用户体验。
277 2
数字孪生与娱乐业:沉浸式体验的提升
数字孪生技术通过创建物理实体的虚拟副本,为娱乐业带来创作自由与沉浸体验的双重提升。本文探讨了该技术在虚拟演唱会、电影游戏制作、主题公园及音乐教育中的应用,以及提升沉浸体验的关键要素,展望了其面临的挑战与未来前景。
"告别蜗牛速度!解锁批量插入数据新姿势,15秒狂插35万条,数据库优化就该这么玩!"
【8月更文挑战第11天】在数据密集型应用中,高效的批量插入是性能优化的关键。传统单条记录插入方式在网络开销、数据库I/O及事务处理上存在明显瓶颈。批量插入则通过减少网络请求次数和数据库I/O操作,显著提升效率。以Python+pymysql为例,通过`executemany`方法,可实现在15秒内将35万条数据快速入库,相较于传统方法,性能提升显著,是处理大规模数据的理想选择。
458 5
宝塔IIS申请Let‘s Encrypt证书
宝塔IIS申请Let‘s Encrypt证书
221 0
1688代采集运系统搭建:实现采购订单处理自动化
1688代采集运系统为海外买家及跨境电商提供一站式服务, 包括商品采集、订单管理、国内集货与国际运输。系统简化采购流程, 提高效率, 并支持多平台与多语言。通过API接口实时获取商品信息, 自动处理订单与物流, 支持多种支付方式, 便于全球用户使用。系统搭建需注册认证并接入API, 进行测试优化。此系统助力国货全球化。
SpringSecurity6从入门到实战之默认登录页面的生成
本文介绍了SpringSecurity在SpringBoot项目中如何自动生成默认登录页面的过程。当访问如`/hello`的受保护路由时,请求会经过多个过滤器。在AuthorizationFilter中,未认证的请求会被拦截并抛出AccessDeniedException。接着,ExceptionTranslationFilter捕获此异常并启动身份验证,调用LoginUrlAuthenticationEntryPoint的commence方法,重定向到/login。DefaultLoginPageGeneratingFilter拦截/login请求,生成并返回默认的登录页面。
AI助理

你好,我是AI助理

可以解答问题、推荐解决方案等