C++ | Leetcode C++题解之第264题丑数II

题目:

题解:

cpp 复制代码
class Solution {
public:
    int nthUglyNumber(int n) {
        vector<int> dp(n + 1);
        dp[1] = 1;
        int p2 = 1, p3 = 1, p5 = 1;
        for (int i = 2; i <= n; i++) {
            int num2 = dp[p2] * 2, num3 = dp[p3] * 3, num5 = dp[p5] * 5;
            dp[i] = min(min(num2, num3), num5);
            if (dp[i] == num2) {
                p2++;
            }
            if (dp[i] == num3) {
                p3++;
            }
            if (dp[i] == num5) {
                p5++;
            }
        }
        return dp[n];
    }
};
相关推荐
载数而行5202 分钟前
算法系列4之插入排序
数据结构·c++·算法·排序算法
智者知已应修善业4 分钟前
【查找指定字符串首位置与数量不区分大小写完整匹配】2025-5-3
c语言·c++·经验分享·笔记·算法
Ronin30512 分钟前
信道管理模块和异步线程模块
开发语言·c++·rabbitmq·异步线程·信道管理
yoyo君~17 分钟前
从内存管理到并发架构:C++ 核心内功修炼指南
开发语言·c++·学习·无人机
问好眼23 分钟前
《算法竞赛进阶指南》0x01 位运算-4.最短Hamilton路径
c++·算法·动态规划·位运算·信息学奥赛
苦藤新鸡23 分钟前
65.搜索平移数组的最小值
算法·leetcode
载数而行52025 分钟前
算法系列5之交换排序
c语言·数据结构·c++·算法·排序算法
重生之后端学习26 分钟前
35. 搜索插入位置
java·数据结构·算法·leetcode·职场和发展·深度优先
Frostnova丶26 分钟前
(1)LeetCode 1. 两数之和
leetcode·哈希算法
楼田莉子28 分钟前
C++并发库介绍(上)
开发语言·c++·学习