当前位置: 首页 > news >正文

leetcode0829. 连续整数求和-hard

1 题目: 连续整数求和

官方标定难度:难

给定一个正整数 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 < = 1 0 9 ​​​​​​​ 1 <= n <= 10^9​​​​​​​ 1<=n<=109​​​​​​​

2 solution

由于 n 较大,直接枚举会超时,所以需要分析一下分解的条件:

 n 若分成 k 个整整相加:1 若 k 是奇数  <=>    n 是 k 的倍数  and  n >= k(k+1)/22 若 k 是偶数   <=>   n = mk + k/2  and  n >= k(k+1)/2

代码

class Solution {/** n 分解成连续整数的和:n <= 1e9* n 若分成 k 个整整相加* 1 若 k 是奇数 <=> n 是 k 的倍数  and  n >= k(k+1)/2* 2 若 k 是偶数 <=> n = mk + k/2  and  n >= k(k+1)/2*/
public:int consecutiveNumbersSum(int n) {int cnt = 0;for(int k = 1; k * (k + 1) <= 2 * n; k++){if(k % 2){cnt += n % k == 0;}else{cnt += (n - k / 2) % k == 0;}}return cnt;}
};

结果

在这里插入图片描述

相关文章:

  • python:vars()方法
  • [docker基础四]容器虚拟化基础之 LXC
  • sensitive-word-admin v2.0.0 全新 ui 版本发布!vue+前后端分离
  • Windows 上使用 WSL 2 后端的 Docker Desktop
  • Linux `ifconfig` 指令深度解析与替代方案指南
  • 2025年广东初级消防设施操作员精选练习题
  • Checkmk实战指南:从零构建企业级监控系统
  • 推理还原的干货
  • 深入解析路由策略:从流量控制到策略实施
  • InnoDB结构与表空间文件页的详解
  • 数据结构:树(树的定义和基本术语)
  • Docker磁盘空间不足问题
  • C++字符串处理:高效操作与常见陷阱
  • 养生:为健康生活筑牢根基
  • vue3使用tailwindcss报错问题
  • stm32之IIC
  • 内网穿透系列三:开源本地服务公网映射工具 tunnelmole
  • 初等数论--欧拉定理及证明
  • 数仓-范式建模、维度建模、雪花模型、星型模型对比及其适用范围
  • 基于OpenCV的人脸识别:FisherFaceRecognizer算法
  • 王毅同印度国家安全顾问多瓦尔通电话
  • 竞彩湃|德甲欧冠资格竞争白热化,伯恩茅斯主场迎恶战
  • 巴基斯坦关闭全部领空
  • 五粮液董事长:茅台1935已脱离千元价位带,五粮液在千元价位已逐步摆脱其他竞品纠缠
  • 新村回响:一周城市生活
  • 从上海首个到成片复制,闵行零工市场如何优化劳动就业服务?