输入: n = 10
输出: 12
解释: 1, 2, 3, 4, 5, 6, 8, 9, 10, 12 是前 10 个丑数。
质因数(素因数或质因子)在数论里是指能整除给定正整数的质数。
class Solution {
public int nthUglyNumber(int n) {
// 丑数可以递推:丑数 = 某较小丑数 * 某因子( 2, 3 ,5 三个其中之一)
// 此处是三种情况下的递推下标,初始化为 0
int index2 = 0;
int index3 = 0;
int index5 = 0;
// 状态转移方程
// dp[i] 代表第 i + 1 个丑数(下标从 0 开始)
int[] dp = new int[n];
// 边界值
// 第一个丑数是 1
dp[0] = 1;
// 状态转移方程
for (int i = 1; i < n; i++) {
// 由下标当前指向的丑数以及三个质因子递推出来的新丑数
int factor2 = dp[index2] * 2;
int factor3 = dp[index3] * 3;
int factor5 = dp[index5] * 5;
// 当前第 i + 1 个丑数(dp[i])就上面三个丑数的最小值
dp[i] = Math.min(Math.min(factor2, factor3), factor5);
// 取了哪个因子递推出来的丑数,就将哪个因子的索引自增
if (dp[i] == factor2)
index2++;
if (dp[i] == factor3)
index3++;
if (dp[i] == factor5)
index5++;
}
// 返回第 n 个丑数
return dp[n - 1];
}
}
class Solution {
fun nthUglyNumber(n: Int): Int {
// 丑数可以递推:丑数 = 某较小丑数 * 某因子( 2, 3 ,5 三个其中之一)
var index2 = 0
var index3 = 0
var index5 = 0
// 状态转移方程
// dp[i] 代表第 i + 1 个丑数
val dp = IntArray(n)
// 边界值
// 第一个丑数是 1
dp[0] = 1
// 状态转移方程
for (i in 1 until n) {
val factor2 = dp[index2] * 2
val factor3 = dp[index3] * 3
val factor5 = dp[index5] * 5
// 当前第 i + 1 个丑数就取由之前的丑数递推出来的丑数的最小值
dp[i] = Math.min(Math.min(factor2, factor3), factor5)
// 取了哪个因子递推出来的丑数,就将哪个因子的索引自增
if (dp[i] == factor2)
index2++
if (dp[i] == factor3)
index3++
if (dp[i] == factor5)
index5++
}
// 返回第 n 个丑数
return dp[n - 1]
}
}