1. 程式人生 > 其它 >.Net Core微服務——Consul(1):服務發現

.Net Core微服務——Consul(1):服務發現

我們把只包含質因子 2、3 和 5 的數稱作醜數(Ugly Number)。求按從小到大的順序的第 n 個醜數。

示例:

輸入: n = 10
輸出: 12
解釋: 1, 2, 3, 4, 5, 6, 8, 9, 10, 12 是前 10 個醜數。
說明:

1是醜數。
n不超過1690。

來源:力扣(LeetCode)
連結:https://leetcode-cn.com/problems/chou-shu-lcof
著作權歸領釦網路所有。商業轉載請聯絡官方授權,非商業轉載請註明出處。

import java.util.Scanner;

class Solution {
    public int nthUglyNumber(int n) {
        int[] dp = new int[n + 1];
        dp[1] = 1;
        int p1 = 1, p2 = 1, p3 = 1;
        for (int i = 2; i <= n; ++i) {
            dp[i] = Math.min(dp[p1] * 2, Math.min(dp[p2] * 3, dp[p3] * 5));
            if (dp[i] == dp[p1] * 2) {
                p1++;
            }
            if (dp[i] == dp[p2] * 3) {
                p2++;
            }
            if (dp[i] == dp[p3] * 5) {
                p3++;
            }
        }
        return dp[n];
    }

    public static void main(String[] args) {
        Scanner in = new Scanner(System.in);
        while (in.hasNext()) {
            System.out.println(new Solution().nthUglyNumber(in.nextInt()));
        }
    }
}
心之所向,素履以往 生如逆旅,一葦以航