剑指Offer——丑数(JS实现)

简介: 剑指Offer——丑数(JS实现)

题目描述

image.png

解题思路

  • 一个丑数一定是其前面的丑数中的某个丑数*2,*3,*5的结果
  • 第一个丑数是1
  • 定义三个指向丑数的指针,初始位置为0
  • 如果一个丑数是哪个指针乘积的结果,那么这个丑数指针向后移,因为这个丑数乘以对应指针也不可能达到最新的丑数的大小。

实现代码

var nthUglyNumber = function(n) {
    const arr = [1];
    if (n === 1) return arr[0];
    let ptr2 = ptr3 = ptr5 = 0;
    for (let i = 1; i <= Number.MAX_VALUE;i++) {
        arr.push(Math.min(arr[ptr2] * 2,arr[ptr3] * 3,arr[ptr5] * 5));
        if (arr[arr.length-1] === arr[ptr2] * 2) {
            ptr2++;
        }
        if (arr[arr.length-1] === arr[ptr3] * 3) {
            ptr3++;
        }
        if (arr[arr.length-1] === arr[ptr5] * 5) {
            ptr5++;
        }
        if (arr.length === n) break;
    }
    return arr[arr.length-1];
};
作者:Always_positive
链接:https://juejin.cn/post/6948663624277688350
来源:稀土掘金
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。
相关文章
|
3月前
|
存储 JSON JavaScript
「offer来了」保姆级巩固你的js知识体系(4.0w字)
该文章提供了JavaScript知识体系的全面复习资料,覆盖了从基础语法到高级特性如闭包、原型链、异步编程等多个方面,并通过大量的面试题和实例代码帮助巩固理解。
「offer来了」保姆级巩固你的js知识体系(4.0w字)
|
7月前
|
JavaScript 前端开发
剑指 Offer 31. 栈的压入、弹出序列 (javascript实现)
剑指 Offer 31. 栈的压入、弹出序列 (javascript实现)
|
7月前
|
JavaScript 前端开发
JavaScript题解剑指offer : 09. 用两个栈实现队列
JavaScript题解剑指offer : 09. 用两个栈实现队列
46 0
|
JavaScript 前端开发 程序员
《剑指 Offer(第 2 版)》树部分JavaScript题解
《剑指 Offer(第 2 版)》树部分JavaScript题解
《剑指 Offer(第 2 版)》树部分JavaScript题解
|
存储 JavaScript 前端开发
《剑指 Offer (第 2 版)》链表部分 JavaScript 题解
《剑指 Offer (第 2 版)》链表部分 JavaScript 题解
《剑指 Offer (第 2 版)》链表部分 JavaScript 题解
|
JavaScript 算法 前端开发
【前端算法】JS实现数字千分位格式化
JS实现数字千分位格式化的几种思路,以及它们之间的性能比较
355 1
|
存储 前端开发 算法
一行代码解决LeetCode实现 strStr()使用JavaScript解题|前端学算法
一行代码解决LeetCode实现 strStr()使用JavaScript解题|前端学算法
165 0
一行代码解决LeetCode实现 strStr()使用JavaScript解题|前端学算法
|
存储 机器学习/深度学习 JavaScript
JS 你最少用几行代码实现深拷贝?
JS 你最少用几行代码实现深拷贝?
JS 你最少用几行代码实现深拷贝?
|
JavaScript 前端开发 算法
JavaScript实现一段时间之后关闭广告
简介:通过JavaScript实现在一段时间之后,广告消失。
136 0
JavaScript实现一段时间之后关闭广告
|
JavaScript 前端开发 算法
JS实现鼠标悬停变色
本文实现的是利用JS实现当鼠标悬停在表格上的时候,表格发生变色。 CSS渲染 JS逻辑 `
224 0
JS实现鼠标悬停变色