【C++数论 因数分解】829. 连续整数求和|1694

本文涉及知识点

数论:质数、最大公约数、菲蜀定理

LeetCode829. 连续整数求和

给定一个正整数 n,返回 连续正整数满足所有数字之和为 n 的组数 。

示例 1:

输入: n = 5

输出: 2

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

示例 2:

输入: n = 9

输出: 3

解释: 9 = 4 + 5 = 2 + 3 + 4

示例 3:

输入: n = 15

输出: 4

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

提示:

1 <= n <= 109

因数分解

如果n是两个连续整数之和,即:a+(a+1)= n,则 a = (n-1)/2。结果:a,a+1。

如果n是三个连续整数之和,则: n/3-1,n/3,n/3+1。

如果n是cnt个连续整数之和,cnt是偶数,令中间的两个数分别是:c,c+1。则cnt/2 × \times × (2 × \times ×c+1) = ctn * c +cnt/2 。如果n =a × \times ×b,a是奇数,b是偶数。则 c = a/2 cnt = b\\times 2 。如: 3 2。如:3 2。如:3\\times2,0,1,2,3

如果cnt时奇数,最中间的是c = n/cnt。

for a = 1 To aa<=n
如果存a
b=n,则通过以上的方式计算cnt,放到哈希激活setCnt中除重。如果a时奇数,setCnt.insert(a) setCnt.insert(n/a*2)。b是奇数类似。

setCnt.size

代码

核心代码

cpp 复制代码
class Solution {
		public:
			int consecutiveNumbersSum(int n) {
				unordered_set<int> setCnt;
				auto Add = [&](int m) {
					int iMin = 0;
					if (m & 1) {
						iMin = n / m - m / 2 ;
					}
					else {
						const int total = n / (m / 2);
						iMin = (total - 1) / 2- (m/2-1);
					}
					if (iMin <= 0) { return; }
					setCnt.emplace(m);
				};
				for (int i = 1; i * i <= n; i++) {
					if (0 != n % i) { continue; }
					const int j = n / i;
					if (i & 1) {
						Add(i);
						Add(j * 2);
					}
					if (j & 1) {
						Add(j);
						Add(i * 2);
					}
				}
				return setCnt.size();
			}
		};

​​​​​​​

扩展阅读

我想对大家说的话
工作中遇到的问题,可以按类别查阅鄙人的算法文章,请点击《算法与数据汇总》。
学习算法:按章节学习《喜缺全书算法册》,大量的题目和测试用例,打包下载。重视操作
有效学习:明确的目标 及时的反馈 拉伸区(难度合适) 专注
闻缺陷则喜(喜缺)是一个美好的愿望,早发现问题,早修改问题,给老板节约钱。
子墨子言之:事无终始,无务多业。也就是我们常说的专业的人做专业的事。
如果程序是一条龙,那算法就是他的是睛
失败+反思=成功 成功+反思=成功

视频课程

先学简单的课程,请移步CSDN学院,听白银讲师(也就是鄙人)的讲解。
https://edu.csdn.net/course/detail/38771

如何你想快速形成战斗了,为老板分忧,请学习C#入职培训、C++入职培训等课程
https://edu.csdn.net/lecturer/6176

测试环境

操作系统:win7 开发环境: VS2019 C++17

或者 操作系统:win10 开发环境: VS2022 C++17

如无特殊说明,本算法用**C++**实现。

相关推荐
VkN2X2X4b32 分钟前
算法性能的渐近与非渐近行为对比的技术9
算法
好家伙VCC37 分钟前
**神经编码新视角:用Python实现生物启发的神经信号压缩与解码算法**在人工智能飞速发展的今天
java·人工智能·python·算法
W23035765738 小时前
经典算法:最长上升子序列(LIS)深度解析 C++ 实现
开发语言·c++·算法
.Ashy.8 小时前
2026.4.11 蓝桥杯软件类C/C++ G组山东省赛 小记
c语言·c++·蓝桥杯
minji...9 小时前
Linux 线程同步与互斥(三) 生产者消费者模型,基于阻塞队列的生产者消费者模型的代码实现
linux·运维·服务器·开发语言·网络·c++·算法
语戚10 小时前
力扣 968. 监控二叉树 —— 贪心 & 树形 DP 双解法递归 + 非递归全解(Java 实现)
java·算法·leetcode·贪心算法·动态规划·力扣·
skywalker_1110 小时前
力扣hot100-7(接雨水),8(无重复字符的最长子串)
算法·leetcode·职场和发展
bIo7lyA8v11 小时前
算法稳定性分析中的输入扰动建模的技术9
算法
CoderCodingNo11 小时前
【GESP】C++三级真题 luogu-B4499, [GESP202603 三级] 二进制回文串
数据结构·c++·算法