Advertisement
650. 2 Keys Keyboard
MediumView on LeetCode
Time: O(n√n)
Space: O(n)
Approach
DP where dp[i] is the min operations to reach i 'A's; for each divisor j of i, dp[i] = min(dp[i], dp[i/j] + j).
650.cs
C#
// Approach: DP where dp[i] is the min operations to reach i 'A's; for each
// divisor j of i, dp[i] = min(dp[i], dp[i/j] + j).
// Time: O(n√n) Space: O(n)
public class Solution
{
public int MinSteps(int n)
{
int[] dp = new int[1005];
dp[0] = 0;
dp[1] = 0;
dp[2] = 2;
dp[3] = 3;
for (int i = 4; i <= n; i++)
{
dp[i] = i;
for (int j = 2; j < i; j++)
{
if (i % j == 0)
dp[i] = Math.Min(dp[i], dp[i / j] + j);
}
}
return dp[n];
}
}Advertisement
Was this solution helpful?