约数个数和约数之和算法总结

知识概览

约数个数

基于算数基本定理,假设N分解质因数的结果为

N = p_1^{\alpha_{1}}p_2^{\alpha_{2}} \cdots p_k^{\alpha_{k}}

可得对于N的任何一个约数d,有

d = p_1^{\beta_{1}}p_2^{\beta_{2}} \cdots p_k^{\beta_{k}}, 0\leqslant \beta_{i}\leqslant \alpha_{i}

因为N的每一个约数和\beta_{1}~\beta_{k}的一种选法是一一对应的,根据乘法原理可得,

一个数的约数个数为

(\alpha_{1} + 1)(\alpha_{2} + 1) \cdots (\alpha_{k} + 1)

约数之和

一个数的约数之和公式为

(p_1^{0} + p_1^{1} + \cdots + p_1^{\alpha_1})\cdots (p_k^{0} + p_k^{1} + \cdots + p_k^{\alpha_k})

多项式乘积的每一项为

p_1^{\beta_{1}}p_2^{\beta_{2}} \cdots p_k^{\beta_{k}}

正好对应的是一个数的每一个约数。

例题展示

约数个数

题目链接

活动 - AcWing系统讲解常用算法与数据结构,给出相应代码模板,并会布置、讲解相应的基础算法题目。icon-default.png?t=N7T8https://www.acwing.com/problem/content/872/

代码
#include <iostream>
#include <algorithm>
#include <unordered_map>

using namespace std;

typedef long long LL;

const int mod = 1e9 + 7;

int main()
{
    int n;
    cin >> n;
    
    unordered_map<int, int> primes;
    while (n--)
    {
        int x;
        cin >> x;
        
        for (int i = 2; i <= x / i; i++)
            while (x % i == 0)
            {
                x /= i;
                primes[i]++;
            }
            
        if (x > 1) primes[x]++;
    }
    
    LL res = 1;
    for (auto prime : primes) res = res * (prime.second + 1) % mod;
    
    cout << res << endl;
    
    return 0;
}

约数之和

题目链接

活动 - AcWing系统讲解常用算法与数据结构,给出相应代码模板,并会布置、讲解相应的基础算法题目。icon-default.png?t=N7T8https://www.acwing.com/problem/content/873/

代码
#include <iostream>
#include <algorithm>
#include <unordered_map>

using namespace std;

typedef long long LL;

const int mod = 1e9 + 7;

int main()
{
    int n;
    cin >> n;
    
    unordered_map<int, int> primes;
    while (n--)
    {
        int x;
        cin >> x;
        
        for (int i = 2; i <= x / i; i++)
            while (x % i == 0)
            {
                x /= i;
                primes[i]++;
            }
            
        if (x > 1) primes[x]++;
    }
    
    LL res = 1;
    for (auto prime : primes)
    {
        int p = prime.first, a = prime.second;
        LL t = 1;
        while (a--) t = (t * p + 1) % mod;
        res = res * t % mod;
    }
    
    cout << res << endl;
    
    return 0;
}

参考资料

  1. AcWing算法基础课

相关推荐

  1. 算法】KY3 的个数

    2024-01-13 03:10:02       46 阅读
  2. 双指针算法篇:两之和 、三之和

    2024-01-13 03:10:02       40 阅读
  3. leetCode算法—15. 三之和

    2024-01-13 03:10:02       62 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-01-13 03:10:02       94 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-01-13 03:10:02       100 阅读
  3. 在Django里面运行非项目文件

    2024-01-13 03:10:02       82 阅读
  4. Python语言-面向对象

    2024-01-13 03:10:02       91 阅读

热门阅读

  1. [树莓派]给树莓派装pyinstaller环境

    2024-01-13 03:10:02       60 阅读
  2. Pandas实战100例 | 案例 9: 数据重塑 - `pivot` 和 `melt`

    2024-01-13 03:10:02       49 阅读
  3. SQL server 给列添加描述

    2024-01-13 03:10:02       69 阅读
  4. 图像处理中常用的距离

    2024-01-13 03:10:02       55 阅读
  5. c++对象拷贝与堆中的对象实例拷贝

    2024-01-13 03:10:02       60 阅读
  6. 77. 组合(回溯)

    2024-01-13 03:10:02       53 阅读
  7. go-zero 如何在任意地方获取yaml中的值

    2024-01-13 03:10:02       49 阅读
  8. Web前端篇——element-plus组件设置全局中文

    2024-01-13 03:10:02       53 阅读
  9. 100. 相同的树

    2024-01-13 03:10:02       51 阅读
  10. mysql 一对多 合并多个通过 逗号拼接展示

    2024-01-13 03:10:02       53 阅读
  11. python - 依赖 pycryptodome

    2024-01-13 03:10:02       51 阅读