返回介绍

solution / 2100-2199 / 2177.Find Three Consecutive Integers That Sum to a Given Number / README

发布于 2024-06-17 01:03:09 字数 2288 浏览 0 评论 0 收藏 0

2177. 找到和为给定整数的三个连续整数

English Version

题目描述

给你一个整数 num ,请你返回三个连续的整数,它们的  为_ _num 。如果 num 无法被表示成三个连续整数的和,请你返回一个  数组。

 

示例 1:

输入:num = 33
输出:[10,11,12]
解释:33 可以表示为 10 + 11 + 12 = 33 。
10, 11, 12 是 3 个连续整数,所以返回 [10, 11, 12] 。

示例 2:

输入:num = 4
输出:[]
解释:没有办法将 4 表示成 3 个连续整数的和。

 

提示:

  • 0 <= num <= 1015

解法

方法一:数学

假设三个连续的整数分别为 $x-1$, $x$, $x+1$,则它们的和为 $3x$,因此 $num$ 必须是 $3$ 的倍数。如果 $num$ 不是 $3$ 的倍数,则无法表示成三个连续整数的和,返回空数组。否则,令 $x = \frac{num}{3}$,则 $x-1$, $x$, $x+1$ 就是三个连续整数,它们的和为 $num$。

时间复杂度 $O(1)$,空间复杂度 $O(1)$。

class Solution:
  def sumOfThree(self, num: int) -> List[int]:
    x, mod = divmod(num, 3)
    return [] if mod else [x - 1, x, x + 1]
class Solution {
  public long[] sumOfThree(long num) {
    if (num % 3 != 0) {
      return new long[] {};
    }
    long x = num / 3;
    return new long[] {x - 1, x, x + 1};
  }
}
class Solution {
public:
  vector<long long> sumOfThree(long long num) {
    if (num % 3) {
      return {};
    }
    long long x = num / 3;
    return {x - 1, x, x + 1};
  }
};
func sumOfThree(num int64) []int64 {
  if num%3 != 0 {
    return []int64{}
  }
  x := num / 3
  return []int64{x - 1, x, x + 1}
}
function sumOfThree(num: number): number[] {
  if (num % 3) {
    return [];
  }
  const x = Math.floor(num / 3);
  return [x - 1, x, x + 1];
}

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。
列表为空,暂无数据
    我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
    原文