千家信息网

golang刷leetcode技巧之如何实现丑数

发表于:2025-12-02 作者:千家信息网编辑
千家信息网最后更新 2025年12月02日,这篇文章主要介绍了golang刷leetcode技巧之如何实现丑数,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。我们把只包含因子 2、
千家信息网最后更新 2025年12月02日golang刷leetcode技巧之如何实现丑数

这篇文章主要介绍了golang刷leetcode技巧之如何实现丑数,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。

我们把只包含因子 2、3 和 5 的数称作丑数(Ugly Number)。求按从小到大的顺序的第 n 个丑数。

示例:

输入: n = 10输出: 12解释:  是前 10 个丑数。

说明:

  1. 1 是丑数。

  2. n 不超过1690。

注意:本题与主站 264 题相同:https://leetcode-cn.com/problems/ugly-number-ii/

解题思路

1,这是一个典型的动态规划题目

2,求出n个最小的丑数 2^p2*3^p3*5^p5

3,状态转移方程为dp[i]=min(dp[p2]*2,dp[p3]*3,dp[p5]*5)

4,最终返回结果为dp[n-1]

代码实现

func nthUglyNumber(n int) int {  dp:=make([]int,n)  dp[0]=1  p2:=0  p3:=0  p5:=0  for i:=1;i      dp[i]=min(dp[p2]*2,dp[p3]*3,dp[p5]*5)      if dp[i]==dp[p2]*2{          p2++      }      if dp[i]==dp[p3]*3{          p3++      }       if dp[i]==dp[p5]*5{          p5++      }  }  return dp[n-1]}func min(a,b,c int)int{    if a<=b && a<=c{        return a    }    if b<=a && b<=c{        return b    }    return c}
/*class Solution { public int nthUglyNumber(int n) { int p2=0,p3=0,p5=0; int[] dp=new int[n]; dp[0]=1; for(int i=1;i dp[i]=Math.min(dp[p2]*2,Math.min(dp[p3]*3,dp[p5]*5)); if(dp[i]==dp[p2]*2) p2++; if(dp[i]==dp[p3]*3) p3++; if(dp[i]==dp[p5]*5) p5++; } return dp[n-1]; } // 一个十分巧妙的动态规划问题 // 1.我们将前面求得的丑数记录下来,后面的丑数就是前面的丑数*2,*3,*5 // 2.但是问题来了,我怎么确定已知前面k-1个丑数,我怎么确定第k个丑数呢 // 3.采取用三个指针的方法,p2,p3,p5 // 4.index2指向的数字下一次永远*2,p3指向的数字下一次永远*3,p5指向的数字永远*5 // 5.我们从2*p2 3*p3 5*p5选取最小的一个数字,作为第k个丑数 // 6.如果第K个丑数==2*p2,也就是说前面0-p2个丑数*2不可能产生比第K个丑数更大的丑数了,所以p2++ // 7.p3,p5同理 // 8.返回第n个丑数
}*/

感谢你能够认真阅读完这篇文章,希望小编分享的"golang刷leetcode技巧之如何实现丑数"这篇文章对大家有帮助,同时也希望大家多多支持,关注行业资讯频道,更多相关知识等着你来学习!

数字 篇文章 指向 技巧 最小 动态 问题 规划 巧妙 相同 从小到大 三个 也就是 也就是说 从小 代码 价值 兴趣 典型 同时 数据库的安全要保护哪些东西 数据库安全各自的含义是什么 生产安全数据库录入 数据库的安全性及管理 数据库安全策略包含哪些 海淀数据库安全审计系统 建立农村房屋安全信息数据库 易用的数据库客户端支持安全管理 连接数据库失败ssl安全错误 数据库的锁怎样保障安全 c 下拉框内容从数据库拿 长沙学软件开发哪个学校最好 杭州汉立互联网科技 汉服 大型网站需要什么服务器配置 计算机软件开发规范 多功能软件开发厂家报价 湖南服务器硬盘回收云空间 网络安全微网文150字 富民信息化软件开发价格信息 魔兽世界服务器公会 江苏融集网络技术有限公司 华为ai软件开发面试 企业管理系统数据库 吉林专业网络技术服务咨询报价 电脑有线宽带无法连接远程服务器 32g内存的服务器哪个好用 凭证服务器地址失败 网络安全威胁主要来自那些 手机软件开发特征 云端数据库设计入口 分布式网络安全控制 生物样本管理数据库 凡科互联网科技股份有限公司叶枫 广西汇利来网络技术有限公司 深圳易通天软件开发有限公司 工行杭州软件开发中心996 ai需要多大的数据库 稳定耕地数据库 国家安全法信息网络安全论文 软件开发 结构化
0