3857. Minimum Cost to Split into Ones
Description
You are given an integer n.
In one operation, you may split an integer x into two positive integers a and b such that a + b = x.
The cost of this operation is a * b.
Return an integer denoting the minimum total cost required to split the integer n into n ones.
Β
Example 1:
Input: n = 3
Output: 3
Explanation:
One optimal set of operations is:
x | a | b | a + b | a * b | Cost |
|---|---|---|---|---|---|
| 3 | 1 | 2 | 3 | 2 | 2 |
| 2 | 1 | 1 | 2 | 1 | 1 |
Thus, the minimum total cost is 2 + 1 = 3.
Example 2:
Input: n = 4
Output: 6
Explanation:
One optimal set of operations is:
x | a | b | a + b | a * b | Cost |
|---|---|---|---|---|---|
| 4 | 2 | 2 | 4 | 4 | 4 |
| 2 | 1 | 1 | 2 | 1 | 1 |
| 2 | 1 | 1 | 2 | 1 | 1 |
Thus, the minimum total cost is 4 + 1 + 1 = 6.
Β
Constraints:
1 <= n <= 500
Solutions
Solution 1: Math
To minimize the total cost, we first split \(n\) into \(1\) and \(n-1\), with a cost of \(1 \cdot (n-1) = n-1\). Next, we split \(n-1\) into \(1\) and \(n-2\), with a cost of \(1 \cdot (n-2) = n-2\).
We continue this process until we split \(2\) into \(1\) and \(1\), with a cost of \(1 \cdot 1 = 1\). Therefore, the total cost is \((n-1) + (n-2) + \ldots + 2 + 1 = \frac{n(n-1)}{2}\).
The time complexity is \(O(1)\), and the space complexity is \(O(1)\).
1 2 3 | |
1 2 3 4 5 | |
1 2 3 4 5 6 | |
1 2 3 | |
1 2 3 | |