把只包含质因子2、3和5
的数称作丑数(Ugly Number
)。
例如6、8
都是丑数,但14
不是,因为它包含质因子7
。
习惯上我们把1
当做是第一个丑数。求按从小到大的顺序的第N
个丑数。
丑数只能被2、3、5
整除,说明第n
个丑数只能是0 - n-1
中某个丑数✖️2
、✖️3
、✖️5
的结果。
而且,这个数即第0 - n-1
个丑数✖️2
、✖️3
、✖️5
的结果中比第n-1
个丑数大的最小值。
按照上面的规律,我们可以依次求出第0 - n
个丑数。
简单做法:
- 1.每次把第
0 - n-1
个丑数✖️(2、3、5)
- 2.分别找到第
0 - n-1
个丑数✖️2
、✖️3
、✖️5
的结果中比第n-1
个丑数大的最小值。 - 3.比较三个数取最小值加入到丑数队列中
优化:
- 1.前面的数不必每个都乘
- 2.记录下✖️
(2、3、5)
后刚好比当前最大丑数大的这三个值的下标i2,i3,i5
- 3.下次比较从这
i2,i3,i5
三个下标开始乘起 - 4.最后取
arr[i2]✖️2、arr[i3]✖️3、arr[i5]✖️5
的最小值
function GetUglyNumber_Solution(index) {
if (index <= 0) {
return 0;
}
let arr = [1];
let i2 = i3 = i5 = 0;
let cur = 0;
while (arr.length < index) {
arr.push(Math.min(arr[i2] * 2, arr[i3] * 3, arr[i5] * 5));
const current = arr[arr.length - 1];
while (arr[i2] * 2 <= current) {
i2++;
}
while (arr[i3] * 3 <= current) {
i3++;
}
while (arr[i5] * 5 <= current) {
i5++;
}
}
return arr[index - 1];
}