Skip to main content

0441 - Arranging Coins (Easy)

https://leetcode.com/problems/arranging-coins/

Problem Statement

You have n coins and you want to build a staircase with these coins. The staircase consists of k rows where the ith row has exactly i coins. The last row of the staircase may be incomplete.

Given the integer n, return the number of complete rows of the staircase you will build.

Example 1:

Input: n = 5
Output: 2
Explanation: Because the 3rd row is incomplete, we return 2.

Example 2:

Input: n = 8
Output: 3
Explanation: Because the 4th row is incomplete, we return 3.

Constraints:

  • 1 <= n <= 2^31 - 1

Approach 1: Math

Written by @wingkwong
class Solution {
public:
int arrangeCoins(int n) {
// Gauss' formula
// k * (k + 1) / 2 <= n
// k * (k + 1 / 2) ^ 2 - 1 / 4 <= n
// k = sqrt(2 * n + 1 / 4) - 1 / 2
return sqrt(2 *(long long) n + 0.25) - 0.5;
}
};
Prerequisite
Written by @wingkwong
class Solution {
public:
int arrangeCoins(int n) {
// init possible range
long long l = 1, r = n;
while (l < r) {
// get the middle one
// for even number of elements, take the upper one
long long m = l + (r - l + 1) / 2;
// for m rows, how many coins can be put?
long long total = m * (m + 1) / 2;
// exclude m
if (n < total) r = m - 1;
// include m
else l = m;
}
return l;
}
};