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(nums[i]) m=max(nums[i])
  • 空间复杂度 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和我的个人博客,原创不易,转载经作者同意后请附上原文链接哦~

千篇源码题解已开源

相关推荐
itzixiao16 分钟前
L1-067 洛希极限(10分)[java][python]
java·开发语言·算法
jinyishu_22 分钟前
链表经典OJ题
c语言·数据结构·算法·链表
葫三生28 分钟前
三生原理文章被AtomGit‌开源社区收录的意义探析?
人工智能·深度学习·神经网络·算法·搜索引擎·开源·transformer
AI进化营-智能译站31 分钟前
ROS2 C++开发系列15-模板实现通用算法|宏定义ROS2调试开关|一次编码适配多平台
java·c++·算法·ai
刀法如飞33 分钟前
Java数组去重的20种实现方式——指导AI解决不同问题的思路
java·算法·面试
aXin_ya34 分钟前
微服务第九天 分布式缓存(Redis)
分布式·缓存·微服务
代码飞天36 分钟前
CTF之内存取证——瞬息万变成为一瞬
安全·web安全·缓存
良木生香39 分钟前
【C++初阶】STL——Vector从入门到应用完全指南(1)
开发语言·c++·神经网络·算法·计算机视觉·自然语言处理·数据挖掘
Brilliantwxx39 分钟前
【C++】String的模拟实现(代码实现与坑点讲解)
开发语言·c++·笔记·算法
憨波个1 小时前
【说话人日志】DOVER:diarization 输出融合算法
人工智能·算法·音频·语音识别·聚类