返回介绍

solution / 1700-1799 / 1739.Building Boxes / README

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

1739. 放置盒子

English Version

题目描述

有一个立方体房间,其长度、宽度和高度都等于 n 个单位。请你在房间里放置 n 个盒子,每个盒子都是一个单位边长的立方体。放置规则如下:

  • 你可以把盒子放在地板上的任何地方。
  • 如果盒子 x 需要放置在盒子 y 的顶部,那么盒子 y 竖直的四个侧面都 必须 与另一个盒子或墙相邻。

给你一个整数 n ,返回接触地面的盒子的 最少 可能数量_。_

 

示例 1:

输入:n = 3
输出:3
解释:上图是 3 个盒子的摆放位置。
这些盒子放在房间的一角,对应左侧位置。

示例 2:

输入:n = 4
输出:3
解释:上图是 3 个盒子的摆放位置。
这些盒子放在房间的一角,对应左侧位置。

示例 3:

输入:n = 10
输出:6
解释:上图是 10 个盒子的摆放位置。
这些盒子放在房间的一角,对应后方位置。

 

提示:

  • 1 <= n <= 109

解法

方法一:数学规律

根据题目描述,层数最高的盒子需要放在墙角,并且盒子的摆放呈阶梯状,这样可以使得接触地面的盒子数量最少。

假设盒子摆放 $k$ 层,从上到下,每一层如果摆满,那么个数分别是 $1, 1+2, 1+2+3, \cdots, 1+2+\cdots+k$。

如果此时盒子还有剩余,那么可以从最低一层继续摆放,假设摆放 $i$ 个,那么累计可摆放的盒子个数为 $1+2+\cdots+i$。

时间复杂度 $O(\sqrt{n})$,其中 $n$ 为题目给定的盒子数量。空间复杂度 $O(1)$。

class Solution:
  def minimumBoxes(self, n: int) -> int:
    s, k = 0, 1
    while s + k * (k + 1) // 2 <= n:
      s += k * (k + 1) // 2
      k += 1
    k -= 1
    ans = k * (k + 1) // 2
    k = 1
    while s < n:
      ans += 1
      s += k
      k += 1
    return ans
class Solution {
  public int minimumBoxes(int n) {
    int s = 0, k = 1;
    while (s + k * (k + 1) / 2 <= n) {
      s += k * (k + 1) / 2;
      ++k;
    }
    --k;
    int ans = k * (k + 1) / 2;
    k = 1;
    while (s < n) {
      ++ans;
      s += k;
      ++k;
    }
    return ans;
  }
}
class Solution {
public:
  int minimumBoxes(int n) {
    int s = 0, k = 1;
    while (s + k * (k + 1) / 2 <= n) {
      s += k * (k + 1) / 2;
      ++k;
    }
    --k;
    int ans = k * (k + 1) / 2;
    k = 1;
    while (s < n) {
      ++ans;
      s += k;
      ++k;
    }
    return ans;
  }
};
func minimumBoxes(n int) int {
  s, k := 0, 1
  for s+k*(k+1)/2 <= n {
    s += k * (k + 1) / 2
    k++
  }
  k--
  ans := k * (k + 1) / 2
  k = 1
  for s < n {
    ans++
    s += k
    k++
  }
  return ans
}

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

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

发布评论

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