题目描述:
设计一个算法,找出只含素因子2
,3
,5
的第 n 小的数。
符合条件的数如:1, 2, 3, 4, 5, 6, 8, 9, 10, 12...
我们可以认为1
也是一个丑数
样例
如果n = 9
, 返回 10
挑战
要求时间复杂度为O(nlogn)或者O(n)
解题:
class Solution {
/**
* @param n an integer
* @return the nth prime number as description.
*/
public int nthUglyNumber(int n) {
List<Integer> uglys = new ArrayList<Integer>();
uglys.add(1);
int p2 = 0, p3 = 0, p5 = 0;
// p2, p3 & p5 share the same queue: uglys
for (int i = 1; i < n; i++) {
int lastNumber = uglys.get(i - 1);
while (uglys.get(p2) * 2 <= lastNumber) p2++;
while (uglys.get(p3) * 3 <= lastNumber) p3++;
while (uglys.get(p5) * 5 <= lastNumber) p5++;
uglys.add(Math.min(
Math.min(uglys.get(p2) * 2, uglys.get(p3) * 3),
uglys.get(p5) * 5
));
}
return uglys.get(n - 1);
}
};