【劍指offer】49.醜數

49.醜數

面試題49. 醜數

難度中等26

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

示例:

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

說明:

  1. 1 是醜數。
  2. n 不超過1690。
//dp問題  
//思路 我們知道醜數是可以被2 or 3 or 5 連續整除的。如果==1 就是醜數
// 初始化 dp[0] = 1;   1*2=2   1*3=3  1*5 =5 min = 2
// dp[1] = 2  a=1;
//  2*2 = 4     1*3 = 3     1*5 = 5     min = 3
// dp[2] = 3  b=3;
//如此反覆進行計算  dp方程 :  dp[Math.min(n2,Math.min(n3,n5))] 
//time :O(n)
//space : O(n)
public int nthUglyNumber(int n) {
    if(n<6) return n;
    int [] dp = new int [n];
    dp[0] = 1;
    int a = 0, b = 0, c = 0;
    for(int i=1;i<n;i++){
        int n2 = dp[a] * 2,n3 = dp[b] * 3, n5 = dp[c] * 5;
        dp[i] = Math.min(n2,Math.min(n3,n5));
        if(dp[i] == n2) a++;
        if(dp[i] == n3) b++;
        if(dp[i] == n5) c++;
    }
    return dp[n-1];
}
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章