当前位置: 首页 > 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;}
};

结果

在这里插入图片描述

http://www.dtcms.com/a/183037.html

相关文章:

  • 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算法
  • vue2 上传pdf,拖拽盖章,下载图片
  • 项目管理从专家到小白
  • Information Fusion期刊期刊投稿经验分享
  • Docker使用小结
  • vim的配置
  • Qt解决自定义窗口样式不生效问题
  • 【小沐学GIS】基于C++绘制二维瓦片地图2D Map(QT、OpenGL、GIS)
  • Python与YOLO:自动驾驶中的实时物体检测
  • python:ASCII-generator 实用教程
  • MySQL COUNT(*) 查询优化详解!