题目描述

给定一个正整数 N ,试求有多少组连续正整数满足所有数字之和为 N ?

示例1

        输入:
5
输出:
2
解释:
5 = 5 = 2 + 3,共有两组连续整数([5],[2,3])求和后为 5。

示例2

        输入:
9
输出:
3
解释:
9 = 9 = 4 + 5 = 2 + 3 + 4

示例3

        输入:
15
输出:
4
解释:
15 = 15 = 8 + 7 = 4 + 5 + 6 = 1 + 2 + 3 + 4 + 5

提示

  • 1 <= N <= 10^9

题解

这是一道非常经典的数学题,挺基础的,不知道为什么这也能算困难难度的题目?

暴力法

遍历所有的连续数字区间 (i, j) ,然后求和看等不等于 N 。这种方法时间复杂度是 ,显然不可行。

暴力法优化

遍历所有的连续数字区间的左端点 i。然后假设区间长度为 n ,那么根据求和公式有 (2i+n-1)n/2=N ,然后只需要看这个方程的解是否是整数就行。时间复杂度可以降到 ,但还是太高了。

数学方法

根据上面的求和公式,对于起点 i 和长度 n ,求和得到 (2i+n-1)n/2=N 。我们可以先粗略推算一下 i 和 n 的范围,起点 i 的范围是 [1, N]毋庸置疑,而区间长度 n 的范围就可以考究一下了,一个出发点是:上面式子可以解出 i=(N-n(n-1)/2)/n ,而 i>=1 ,可以解出 (n+1)n<=2N ,所以 n 的范围其实只有根号 N 级别,可以直接遍历。另一个出发点是最小的 n 个数加起来就是 1 加到 n 等于 n(n+1)/2 ,这个要小于等于 N ,解出来也是 (n+1)n<=2N 。

所以我们只需要从 1 开始遍历 n ,直到 (n+1)n>2N 为止,然后判断 (N-n(n-1)/2)/n 是否是整数就行了(前面终止条件可以保证 i 一定大于 0 )。

最终时间复杂度降到了

代码

数学方法(c++)

        class Solution {public:int consecutiveNumbersSum(int N) {int res = 0;for (int n = 1; (n + 1) * n <= 2 * N; ++n) {if ((N - n * (n - 1) / 2) % n == 0) res++;}return res;}
};

数学方法(python)

        class Solution:def consecutiveNumbersSum(self, N: int) -> int:res = 0for n in range(1, N+1):if n * (n + 1) > 2 * N:breakif (N - n * (n - 1) // 2) % n == 0:res += 1return res

后记

这题还可以用质因数分解等方法进一步优化,但是没有必要。

每日算法系列【LeetCode 829】连续整数求和相关推荐

  1. leetcode 829 连续整数求和

    leetcode 829 连续整数求和 Q: 给定一个正整数 N,试求有多少组连续正整数满足所有数字之和为 N? 思路: 假设有 K,我们需要满足满足 N = (x+1)+ (x+2) + - + ( ...

  2. Leetcode 829. 连续整数求和 C++

    Leetcode 829. 连续整数求和 题目 给定一个正整数 N,试求有多少组连续正整数满足所有数字之和为 N? 测试样例 示例 1: 输入: 5 输出: 2 解释: 5 = 5 = 2 + 3,共 ...

  3. leetcode 829.连续整数求和

    leetcode 829.连续整数求和 题目: 给定一个正整数 n,返回 连续正整数满足所有数字之和为 n 的组数 . 示例 1: 输入: n = 5 输出: 2 解释: 5 = 2 + 3,共有两组 ...

  4. leetcode 829. 连续整数求和

    题目描述: 给定一个正整数 n,返回 连续正整数满足所有数字之和为 n 的组数 . 示例 1: 输入: n = 5 输出: 2 解释: 5 = 2 + 3,共有两组连续整数([5],[2,3])求和后 ...

  5. LeetCode 829. 连续整数求和(数学)

    1. 题目 给定一个正整数 N,试求有多少组连续正整数满足所有数字之和为 N? 示例 1: 输入: 5 输出: 2 解释: 5 = 5 = 2 + 3,共有两组连续整数([5],[2,3])求和后为 ...

  6. 重复次数最多的 子串_每日算法系列【LeetCode 424】替换后的最长重复字符

    题目描述 给你一个仅由大写英文字母组成的字符串,你可以将任意位置上的字符替换成另外的字符,总共可最多替换 k 次.在执行上述操作后,找到包含重复字母的最长子串的长度. 示例1 输入: s = &quo ...

  7. 829. 连续整数求和

    829. 连续整数求和 原始题目链接:https://leetcode.cn/problems/consecutive-numbers-sum/ 给定一个正整数 n,返回 连续正整数满足所有数字之和为 ...

  8. 求栈中元素个数算法_每日算法系列【LeetCode 315】计算右侧小于当前元素的个数...

    题目描述 给定一个整数数组 nums ,按要求返回一个新数组 counts .数组 counts 有该性质: counts[i] 的值是 nums[i] 右侧小于 nums[i] 的元素的数量. 示例 ...

  9. 如何表示数组所有数都不等于一个数_每日算法系列【LeetCode 523】连续的子数组和...

    题目描述 给定一个包含非负数的数组和一个目标整数 k,编写一个函数来判断该数组是否含有连续的子数组,其大小至少为 2,总和为 k 的倍数,即总和为 n*k,其中 n 也是一个整数. 示例1 输入: [ ...

  10. 数组最大可以开多大_每日算法系列【LeetCode 689】三个无重叠子数组的最大和

    题目描述 给定数组 由正整数组成,找到三个互不重叠的子数组的最大和. 每个子数组的长度为 ,我们要使这 个项的和最大化. 返回每个区间起始索引的列表(索引从 0 开始).如果有多个结果,返回字典序最小 ...

最新文章

  1. VC 下 64bit 整数的显示和读取格式化字串
  2. HTML5基础-Mark标签高亮显示文本
  3. 深入理解STM32内存管理
  4. JAVA语言中流程控制(顺序结构、判断语句、循环语句)
  5. java ini_java读取ini格式的文件
  6. 2020年,哪些行业涨工资最多?
  7. MITRE 发布工控系统的 ATTCK 框架
  8. 转一篇矩阵方面有趣的文章
  9. Win32汇编——内存管理
  10. 使用REST framework
  11. 2016计算机二级java_2016年计算机二级《JAVA》考试练习题
  12. 通过GDI+修改jpg文件EXIF属性
  13. 数据库设计各阶段任务
  14. unbantu...
  15. 阿里国际站用户增长技术探索与实践
  16. Git 使用详解,日常使用 | 什么是git
  17. CPU核数和线程数有什么作用?CPU核数和线程的关系与区别,服务器CPU与电脑主机CPU的区别
  18. Linux signal那些事儿【转】
  19. pandas学习笔记—agg()函数详解
  20. 10.10 CF - 520B

热门文章

  1. 常用的python模块及安装方法
  2. poj 3928 树状数组
  3. python urllib编码
  4. 【leetcode】557. 反转字符串中的单词 III-原地算法
  5. Altium Designer(五):布板技巧
  6. python基础之小数据池,is和==区别 编码问题
  7. 内置模块之configparser
  8. Failed to initialize storage module: user 的解决方式
  9. css 各浏览器里的不同
  10. ArcGIS API for Silverlight之配准JPG图片地图文字倾斜解决方案