leetcode: 441.排列硬币
2021/10/11 6:17:59
本文主要是介绍leetcode: 441.排列硬币,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
题目
来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/arranging-coins
你总共有 n 枚硬币,并计划将它们按阶梯状排列。对于一个由 k 行组成的阶梯,其第 i 行必须正好有 i 枚硬币。阶梯的最后一行 可能 是不完整的。
给你一个数字 n ,计算并返回可形成 完整阶梯行 的总行数。
示例 1:
输入:n = 5
输出:2
解释:因为第三行不完整,所以返回 2 。
示例 2:
输入:n = 8
输出:3
解释:因为第四行不完整,所以返回 3 。
提示:
1 <= n <= 231 - 1
解法
-
二分法:1+2+3+…+k <= n
-
二次函数求解公示, delt = b^2 -4ac
-
二分法 python
class Solution: def arrangeCoins(self, n: int) -> int: if n <= 2: return 1 left, right = 1, n while left < right: mid = (left + right + 1) // 2 if mid * (mid+1) / 2 <= n: left = mid else: right = mid - 1 return left
- 公式法 python
class Solution: def arrangeCoins(self, n: int) -> int: if n <= 2: return 1 return int((pow(8*n+1, 0.5)-1)/2)
复杂度分析
-
时间复杂度:O(logn) 二分法
-
空间复杂度:O(1)
这篇关于leetcode: 441.排列硬币的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2024-05-15PingCAP 黄东旭参与 CCF 秀湖会议,共探开源教育未来
- 2024-05-13PingCAP 戴涛:构建面向未来的金融核心系统
- 2024-05-09flutter3.x_macos桌面os实战
- 2024-05-09Rust中的并发性:Sync 和 Send Traits
- 2024-05-08使用Ollama和OpenWebUI在CPU上玩转Meta Llama3-8B
- 2024-05-08完工标准(DoD)与验收条件(AC)究竟有什么不同?
- 2024-05-084万 star 的 NocoDB 在 sealos 上一键起,轻松把数据库编程智能表格
- 2024-05-08Mac 版Stable Diffusion WebUI的安装
- 2024-05-08解锁CodeGeeX智能问答中3项独有的隐藏技能
- 2024-05-08RAG算法优化+新增代码仓库支持,CodeGeeX的@repo功能效果提升