[LeetCode]313. Super Ugly Number超级丑数,丑数系列看这一道就行了

丑数系列的题看这一道就可以了

/*
    和ugly number2差不多,不过这次的质因子多了,所以用数组来表示质因子的target坐标
    target坐标指的是这个质因子此次要乘的前任丑数是谁
     */
    public int nthSuperUglyNumber(int n, int[] primes) {
        //记录相乘坐标,存的是每个质因子对应相乘搭档在丑数数组中的下标
        int[] target = new int[primes.length];
        //动态规划数组
        int[] dp = new int[n];
        //第一个丑数是0
        dp[0] = 1;
        for (int i = 1; i < n; i++) {
            //每次都要把所有质因子都乘上对应数试试,维护一个min和一个index
            int min  = Integer.MAX_VALUE;
            int index = 0;
            for (int j = 0; j < primes.length; j++) {
                if (min>primes[j]*dp[target[j]])
                {
                    min = primes[j]*dp[target[j]];
                    index = j;
                }
                //别忘了,如果有另外的质因子也组成了相同的数,那么这个质因子的target要跳过
                //因为得到相同丑数的组合只保留一种即可
                //在丑数2中,由于是分别判断2,3,5,所以重复的组合都跳过了
                else if (min==primes[j]*dp[target[j]]) target[j]++;
            }
            //更新dp和target
            dp[i] = min;
            target[index]++;
        }
        return dp[n-1];
    }

 

posted @ 2018-02-27 14:40  stAr_1  阅读(170)  评论(0编辑  收藏  举报