アルゴリズム記録
LeetCodeトピック:
超醜い数は、その素数のすべてが素数配列の素数に現れるような正の整数です。
整数nと整数配列の素数が与えられた場合、n番目の非常に醜い数を返します。
タイトルデータは、n番目の非常に醜い数が32ビットの符号付き整数の範囲内にあることを保証します。
説明する
1.トピック
输入:n = 12, primes = [2,7,13,19]
输出:32
解释:给定长度为 4 的质数数组 primes = [2,7,13,19],前 12 个超级丑数序列为:[1,2,4,7,8,13,14,16,19,26,28,32] 。
复制代码
2.分析
- この質問と醜い数の計算方法はもう1つの変数配列です。醜い数には3つの素数しかなく、この超醜い数の素数は変数配列になります。
- 醜い数の慣習に従ってください。ただし、すべての変数をストレージ用の中間配列に置き換えてください。
class Solution {
public int nthSuperUglyNumber(int n, int[] primes) {
int m = primes.length;
int[] index = new int[m], ret = new int[n + 1], nums = new int[m];
for(int i = 1; i <= n; i++) {
int min = Arrays.stream(nums).min().getAsInt();
ret[i] = min == 0 ? 1 : min;
for(int j = 0; j < m; j++) {
if(min == nums[j]) {
index[j]++;
nums[j] = ret[index[j]] * primes[j];
}
}
}
return ret[n];
}
}
复制代码
要約する
動的計画法。