Golang | Leetcode Golang题解之第313题超级丑数

题目:

题解:

Go 复制代码
func nthSuperUglyNumber(n int, primes []int) int {
    dp := make([]int, n+1)
    m := len(primes)
    pointers := make([]int, m)
    nums := make([]int, m)
    for i := range nums {
        nums[i] = 1
    }
    for i := 1; i <= n; i++ {
        minNum := math.MaxInt64
        for j := range pointers {
            minNum = min(minNum, nums[j])
        }
        dp[i] = minNum
        for j := range nums {
            if nums[j] == minNum {
                pointers[j]++
                nums[j] = dp[pointers[j]] * primes[j]
            }
        }
    }
    return dp[n]
}

func min(a, b int) int {
    if a < b {
        return a
    }
    return b
}
相关推荐
tyb3333331 小时前
leetcode:吃苹果和队列
算法·leetcode·职场和发展
踩坑记录2 小时前
leetcode hot100 74. 搜索二维矩阵 二分查找 medium
leetcode
TracyCoder1232 小时前
LeetCode Hot100(60/100)——55. 跳跃游戏
算法·leetcode
Charlie_lll2 小时前
力扣解题-438. 找到字符串中所有字母异位词
后端·算法·leetcode
qwfys2002 小时前
How to install golang 1.26.0 to Ubuntu 24.04
ubuntu·golang·install
菜鸡儿齐3 小时前
leetcode-有效的括号
linux·算法·leetcode
We་ct3 小时前
LeetCode 102. 二叉树的层序遍历:图文拆解+代码详解
前端·算法·leetcode·typescript
苦藤新鸡3 小时前
65.搜索平移数组的最小值
算法·leetcode
重生之后端学习4 小时前
35. 搜索插入位置
java·数据结构·算法·leetcode·职场和发展·深度优先
Frostnova丶4 小时前
(1)LeetCode 1. 两数之和
leetcode·哈希算法