【LeetCode:264. 丑数 II + 小根堆】

在这里插入代码片

|-----------|
| 🚀 算法题 🚀 |

🌲 算法刷题专栏 | 面试必备算法 | 面试高频算法 🍀
🌲 越难的东西,越要努力坚持,因为它具有很高的价值,算法就是这样✨
🌲 作者简介:硕风和炜,CSDN-Java领域优质创作者🏆,保研|国家奖学金|高中学习JAVA|大学完善JAVA开发技术栈|面试刷题|面经八股文|经验分享|好用的网站工具分享💎💎💎
🌲 恭喜你发现一枚宝藏博主,赶快收入囊中吧🌻
🌲 人生如棋,我愿为卒,行动虽慢,可谁曾见我后退一步?🎯🎯

|-----------|
| 🚀 算法题 🚀 |

🍔 目录

    • [🚩 题目链接](#🚩 题目链接)
    • [⛲ 题目描述](#⛲ 题目描述)
    • [🌟 求解思路&实现代码&运行结果](#🌟 求解思路&实现代码&运行结果)
      • [⚡ 小根堆](#⚡ 小根堆)
        • [🥦 求解思路](#🥦 求解思路)
        • [🥦 实现代码](#🥦 实现代码)
        • [🥦 运行结果](#🥦 运行结果)
    • [💬 共勉](#💬 共勉)

🚩 题目链接

⛲ 题目描述

给你一个整数 n ,请你找出并返回第 n 个 丑数 。

丑数 就是质因子只包含 2、3 和 5 的正整数。

示例 1:

输入:n = 10

输出:12

解释:[1, 2, 3, 4, 5, 6, 8, 9, 10, 12] 是由前 10 个丑数组成的序列。

示例 2:

输入:n = 1

输出:1

解释:1 通常被视为丑数。

提示:

1 <= n <= 1690

🌟 求解思路&实现代码&运行结果


⚡ 小根堆

🥦 求解思路
  1. 根据丑数的定义,0 和负整数一定不是丑数。1 是最小的丑数。对于任意一个丑数 x,其与任意的质因数(2、3、5)相乘,结果(2x、3x、5x)仍为丑数。
  2. 起始先将最小丑数 1 放入队列,每次从队列取出最小值 x,然后将 x 所对应的丑数 2x、3x 和 5x 进行入队。循环n 次,最后出队的值即是答案。
  3. 为了防止同一丑数多次进队,我们需要使用数据结构 Set 来记录入过队列的丑数。
  4. 有了基本的思路,接下来我们就来通过代码来实现一下。
🥦 实现代码
java 复制代码
class Solution {
    int[] nums = new int[]{2,3,5};
    public int nthUglyNumber(int n) {
        Set<Long> set = new HashSet<>();
        Queue<Long> pq = new PriorityQueue<>();
        set.add(1L);
        pq.add(1L);
        for (int i = 1; i <= n; i++) {
            long x = pq.poll();
            if (i == n) return (int)x;
            for (int num : nums) {
                long t = num * x;
                if (!set.contains(t)) {
                    set.add(t);
                    pq.add(t);
                }
            }
        }
        return -1;
    }
}
🥦 运行结果

💬 共勉

|----------------------------------|
| 最后,我想和大家分享一句一直激励我的座右铭,希望可以与大家共勉! |

相关推荐
疯一样的码农2 分钟前
Apache Maven 标准文件目录布局
java·maven·apache
一只小透明啊啊啊啊16 分钟前
Leetcode100子串
算法
木向16 分钟前
leetcode:114. 二叉树展开为链表
算法·leetcode·链表
sky_smile_Allen20 分钟前
[C#] 关于数组的详细解释以及使用注意点
开发语言·算法·c#
Felix666yy22 分钟前
设计模式之建造者模式
java
界面开发小八哥23 分钟前
「Java EE开发指南」如何使用Visual JSF编辑器设计JSP?(一)
java·ide·java-ee·编辑器·myeclipse
先睡25 分钟前
javaEE
java·java-ee
程序猿小D33 分钟前
第三百三十一节 Java网络教程 - Java网络UDP多播
java·网络·udp
灭掉c与java36 分钟前
第五章springboot实现web的常用功能
java·spring boot·spring
希望有朝一日能如愿以偿37 分钟前
力扣题解(新增道路查询后的最短距离II)
算法