Skip to content
On this page

1201. 丑数 III

原题链接:LeetCode 1201. 丑数 III

题目描述

丑数是可以被 a b c 整除的 正整数

给你四个整数:nabc ,请你设计一个算法来找出第 n 个丑数。

示例 1:

  • 输入: n = 3, a = 2, b = 3, c = 5
  • 输出: 4
  • 解释: 丑数序列为 2, 3, 4, 5, 6, 8, 9, 10... 其中第 3 个是 4。

示例 2:

  • 输入: n = 4, a = 2, b = 3, c = 4
  • 输出: 6
  • 解释: 丑数序列为 2, 3, 4, 6, 8, 9, 10, 12... 其中第 4 个是 6。

示例 3:

  • 输入: n = 5, a = 2, b = 11, c = 13
  • 输出: 10
  • 解释: 丑数序列为 2, 4, 6, 8, 10, 11, 12, 13... 其中第 5 个是 10。

提示:

  • 1 <= n, a, b, c <= 109
  • 1 <= a * b * c <= 1018
  • 本题结果在 [1, 2 * 109] 的范围内

难度: Medium


题解代码

javascript
/**
 * @param {number} n
 * @param {number} a
 * @param {number} b
 * @param {number} c
 * @return {number}
 */
// var nthUglyNumber = function(n, a, b, c) {
//   return nthSuperUglyNumber(n, [a, b, c])
// };
// var nthSuperUglyNumber = function(n, primes) {
//   const dp = [0, 1]
//   const p = new Array(primes.length).fill(1)
//   for (i = 2; i <= n + 2; i++) {
//     const min = Math.min(...[].slice.call(p).map((item, idx) => dp[item] * primes[idx]))
//     console.log(min)
//     for (let i = 0, l = p.length; i < l; i++) {
//       if (dp[p[i]] * primes[i] === min) p[i]++
//     }
//     dp[i] = min
//   }
//   console.log(dp)
//   return dp[n + 1]
// };

var nthUglyNumber = function(n, a, b, c) {
  const isUgly = num => {
    return num / a === Math.floor(num / a) || num / b === Math.floor(num / b) || num / c === Math.floor(num / c)
  }
  let count = 1
  let idx = 1
  // let arr = []
  while(count <= n) {
    idx++
    if (isUgly(idx)) {
      count++
      // arr.push(idx)
    }
  }
  // console.log(arr, count)
  return idx
};

技术文档集合