2652. 倍数求和

2652. 倍数求和
难度: 简单
来源: 每日一题 2023.10.17

给你一个正整数 n ,请你计算在 [1,n] 范围内能被 357 整除的所有整数之和。

返回一个整数,用于表示给定范围内所有满足约束条件的数字之和。

示例 1:

复制代码
输入:n = 7
输出:21
解释:在 [1, 7] 范围内能被 3、5、7 整除的所有整数分别是 3、5、6、7 。数字之和为 21 。

示例 2:

复制代码
输入:n = 10
输出:40
解释:在 [1, 10] 范围内能被 3、5、7 整除的所有整数分别是 3、5、6、7、9、10 。数字之和为 40 。

示例 3:

复制代码
输入:n = 9
输出:30
解释:在 [1, 9] 范围内能被 3、5、7 整除的所有整数分别是 3、5、6、7、9 。数字之和为 30 。

提示:

  • 1 <= n <= 10^3
Java 复制代码
class Solution {
    public int sumOfMultiples(int n) {

    }
}
分析与题解

  • 遍历查找 + 暴力搜寻

    这个题目按照遍历查找好像没有啥难度, 就直接遍历查找符合题意的数字即可.

    整体逻辑代码如下所示.

    Java 复制代码
    class Solution {
        public int sumOfMultiples(int n) {
            int result = 0;
            for(int i = 1; i <= n; i++) {
                if(i%3 == 0 || i%5 == 0 || i%7 == 0) {
                    result += i;
                }
            }
            return result;
        }
    }

    复杂度分析:

    • 时间复杂度: O(n), 一次遍历循环, 时间复杂度与n相关.
    • 空间复杂度: O(1), 常量级别的空间复杂度.

    结果如下所示.

  • 等差数列 + 容斥原理

    首先说一下等差数列的概念, 对于这个题目来说就是从 1 - n中 所有能被 m 整除的和, 那我们知道, 会有如下的等差规律 m 2m 3m ... n/m * m, 求这个等差数列的和, 那么就如下所示.

    Java 复制代码
    int sum = m + 2m + 3m + ... + n/m * m
    sum = (1 + 2 + 3 + n/m) * m
    sum = (1 + n/m) * (n/m) / 2 * m

    然后根据容次原理的相关内容.

    我们可以得到 在 1 - n 中能被 3 , 5 , 7 整除的表达式如下所示.

    Java 复制代码
    sun(n, 3) + sun(n, 5) + sun(n, 7) - sun(n, 3 * 5) - sun(n, 3 * 7) - sun(n, 5 * 7) + sun(n, 3 * 5 * 7);

    整体逻辑代码如下所示.

    Java 复制代码
    class Solution {
        public int sun(int n, int m) {
            return (1 + n/m) * (n/m) / 2 * m;
        }
        public int sumOfMultiples(int n) {
            return sun(n, 3) + sun(n, 5) + sun(n, 7) - sun(n, 3 * 5) - sun(n, 3 * 7) - sun(n, 5 * 7) + sun(n, 3 * 5 * 7);
        }
    }

    复杂度分析:

    • 时间复杂度: O(1), 没有遍历, 常量级别的时间复杂度.
    • 空间复杂度: O(1), 常量级别的空间复杂度.

    结果如下所示.

相关推荐
WolfGang0073211 小时前
代码随想录算法训练营Day28 | 509.斐波那契数列、70.爬楼梯、746.使用最小花费爬楼梯
算法
Boop_wu1 小时前
[Java EE] 多线程进阶(JUC)(2)
java·jvm·算法
闻缺陷则喜何志丹2 小时前
【SOSDP模板 容斥原理 逆向思考】3757. 有效子序列的数量|分数未知
c++·算法·力扣·容斥原理·sosdp·逆向思考
CoovallyAIHub2 小时前
如何在手机上轻松识别多种鸟类?我们发现了更简单的秘密……
深度学习·算法·计算机视觉
第二只羽毛2 小时前
遵守robots协议的友好爬虫
大数据·爬虫·python·算法·网络爬虫
艾斯比的日常3 小时前
Java 三色标记算法:并发垃圾回收的核心技术解析
java·开发语言·算法
CoovallyAIHub3 小时前
抛弃LLM!MIT用纯视觉方法破解ARC难题,性能接近人类水平
深度学习·算法·计算机视觉
程序猿编码3 小时前
PRINCE算法的密码生成器:原理与设计思路(C/C++代码实现)
c语言·网络·c++·算法·安全·prince
高洁013 小时前
具身智能-视觉语言导航(VLN)
深度学习·算法·aigc·transformer·知识图谱
Croa-vo3 小时前
TikTok 数据工程师三轮 VO 超详细面经:技术深挖 + 建模推导 + 压力测试全记录
javascript·数据结构·经验分享·算法·面试