LeetCode 1390.四因数:因数分解+缓存

【LetMeFly】1390.四因数:因数分解+缓存

力扣题目链接:https://leetcode.cn/problems/four-divisors/

给你一个整数数组 nums,请你返回该数组中恰有四个因数的这些整数的各因数之和。如果数组中不存在满足题意的整数,则返回 0

示例 1:

复制代码
输入:nums = [21,4,7]
输出:32
解释:
21 有 4 个因数:1, 3, 7, 21
4 有 3 个因数:1, 2, 4
7 有 2 个因数:1, 7
答案仅为 21 的所有因数的和。

示例 2:

复制代码
输入: nums = [21,21]
输出: 64

示例 3:

复制代码
输入: nums = [1,2,3,4,5]
输出: 0

提示:

  • 1 <= nums.length <= 104
  • 1 <= nums[i] <= 105

解题方法:因数分解

如何求一个数 n n n有多少个因数?

用变量 i i i从 1 1 1到 ⌊ n ⌋ \lfloor\sqrt{n}\rfloor ⌊n ⌋遍历,如果 i i i能整除 n n n,则因数个数加二。

特别的,如果 n n n是完全平方数,则前面运算中 n \sqrt{n} n 多统计了一次,要减去。

由于不同的测试用例可能会出现相同的数,所以可以使用一个"全局"缓存或类中的静态变量来避免重复计算。

  • 时间复杂度:单个测试用例 O ( n ) O(n) O(n),所有测试用例总体还需加上 O ( m log ⁡ m ) O(m\log m) O(mlogm),其中 m = max ⁡ ( n u m s i ) m=\max(numsi) m=max(numsi)
  • 空间复杂度 O ( m ) O(m) O(m)

AC代码

C++
cpp 复制代码
/*
 * @LastEditTime: 2026-01-04 18:51:38
 */
class Solution {
private:
    static unordered_map<int, int> cache;

    int gen(int n) {
        if (cache.count(n)) {
            return cache[n];
        }

        int cnt = 0, sum = 0;
        int k = sqrt(n);
        for (int i = 1; i <= k; i++) {
            if (n % i == 0) {
                cnt += 2;
                sum += i + n / i;
            }
        }
        if (k * k == n) {
            cnt--, sum -= k;
        }
        return cache[n] = cnt == 4 ? sum : 0;
    }
public:
    int sumFourDivisors(vector<int>& nums) {
        int ans = 0;
        for (int t : nums) {
            ans += gen(t);
        }
        return ans;
    }
};

unordered_map<int, int> Solution::cache;

同步发文于CSDN和我的个人博客,原创不易,转载经作者同意后请附上原文链接哦~

千篇源码题解已开源

相关推荐
珂朵莉MM5 分钟前
第七届全球校园人工智能算法精英大赛-算法巅峰赛产业命题赛第3赛季优化题--束搜索
人工智能·算法
Omics Pro1 小时前
首个!外源天然产物综合性代谢图谱
数据库·人工智能·算法·机器学习·r语言
voidmort1 小时前
3. 微调(Fine-tuning)与强化学习(RL)的核心思想
python·深度学习·算法
人道领域2 小时前
【LeetCode刷题日记】669.修剪二叉搜索树
开发语言·python·算法
QiLinkOS2 小时前
【从实验室到商业战场:发明专利如何重塑科技与企业的共生生态】
大数据·c语言·数据结构·c++·人工智能·单片机·算法
小白兔奶糖ovo3 小时前
【Leetcode】231. 2的幂
linux·算法·leetcode
xiaoxiaoxiaolll3 小时前
《Light: Science & Applications》合并BIC实现80倍阈值单模运行:超紧凑光子晶体激光器新突破
人工智能·算法·机器学习
Peter·Pan爱编程3 小时前
14. Lambda 表达式:随手可写的函数对象
c++·算法·ai编程
-To be number.wan3 小时前
算法日记 | 暴力枚举
学习·算法
s_w.h4 小时前
【 linux 】动静态库的制作
linux·运维·服务器·算法·bash