LeetCode-非常に醜い数字

アルゴリズム記録

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];
    }
}
复制代码

要約する

動的計画法。

おすすめ

転載: juejin.im/post/7103885112961400862