3958. Minimum Cost to Split into Ones II π
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 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 |
Thus, the minimum total cost is 4 + 1 + 1 = 6.
Β
Constraints:
1 <= n <= 5 * 107
Solutions
Solution 1: Mathematics
To minimize the cost, we should first split \(n\) into \(1\) and \(n - 1\), which costs \(n - 1\); then split \(n - 1\) into \(1\) and \(n - 2\), which costs \(n - 2\). Following this pattern, the total cost is accumulated as \(1 + 2 + \dots + (n - 1) = \frac{n \times (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 | |