丑数
丑数(Ugly Number)是指只包含质因数 2、3 和 5 的正整数。例如,1、2、3、4、5、6、8、9、10、12 等是丑数,而 7、14 等不是(因为包含其他质因数)。通常将 1 视为第一个丑数。
计算第 n 个丑数的方法
使用动态规划结合三指针法高效生成丑数序列:
- 初始化:定义数组
dp存储丑数,dp[0] = 1(第一个丑数)。三个指针p2、p3、p5均初始化为 0,分别表示下一个待乘以 2、3、5 的丑数位置。 - 生成后续丑数:对于每个位置
i(从 1 到 n-1):- 计算候选值:
num2 = dp[p2] * 2,num3 = dp[p3] * 3,num5 = dp[p5] * 5。 - 取最小值:
dp[i] = min(num2, num3, num5)。 - 更新指针:若
dp[i]等于某个候选值,则对应指针加 1(若同时等于多个,则多个指针都加 1)。
- 计算候选值:
- 返回结果:
dp[n-1]即为第 n 个丑数。
示例(计算第 10 个丑数)
- 前 10 个丑数序列:
[1, 2, 3, 4, 5, 6, 8, 9, 10, 12]。 - 第 10 个丑数是 12。
代码实现(Python)
def nthUglyNumber(n: int) -> int:
dp = [1] * n
p2, p3, p5 = 0, 0, 0
for i in range(1, n):
num2 = dp[p2] * 2
num3 = dp[p3] * 3
num5 = dp[p5] * 5
dp[i] = min(num2, num3, num5)
if dp[i] == num2: p2 += 1
if dp[i] == num3: p3 += 1
if dp[i] == num5: p5 += 1
return dp[-1]
# 测试
print(nthUglyNumber(10)) # 输出: 12
算法特点
- 时间复杂度:O(n),只需遍历一次。
- 空间复杂度:O(n),存储丑数序列。
此方法高效避免了逐个数字检查的冗余计算,直接按顺序生成丑数。
核心线程数和最大线程数怎么设置
核心线程数和最大线程数是Java线程池中重要的参数,用来控制线程池中线程的数量和行为。正确地设置这两个参数可以优化系统的性能和资源利用率。本文将详细介绍核心线程
2023-12-01 13:50:09
基于可变形CNN的数显仪表分割与识别方法
目前,对于数显仪表的识别,多采用传统的图像处理及机器学习等方法,在复杂多变的应用场景中,其对字符、数字的识别准确率低,难以满足实时应用的要求。针对以上问题,将传统图像处理技术与深度学习方法相结合,提
资料下载
佚名
2021-05-10 11:14:06
使用51单片机把4位16进制数转成10进制数的方法和程序免费下载
本文档的主要内容详细介绍的是使用51单片机把4位16进制数转成10进制数的方法和程序免费下载。
资料下载
无人岛
2019-08-23 17:30:00
如何进行ASCII码和十六进制数的转换
本文档的主要内容详细介绍的是如何使用51单片机进行ASCII码和十六进制数的转换资料免费下载题目:用查表法将一位十六进制数转换为ASCII码,入口参数放在内部RAM 50H中,出口参数在R0中。
资料下载
吴藩
2019-07-08 17:41:00
丑数系列算法详解
最近读者群里有个读者跟我私信,说去面试微软遇到了一系列和数学相关的算法题,直接懵圈了。我看了下题目,发现这些题其实就是 LeetCode 上面「丑数」系列问题的修改版。
2022-09-14 11:40:11
换一换
- 如何分清usb-c和type-c的区别
- 中国芯片现状怎样?芯片发展分析
- vga接口接线图及vga接口定义
- 芯片的工作原理是什么?
- 华为harmonyos是什么意思,看懂鸿蒙OS系统!
- 什么是蓝牙?它的主要作用是什么?
- ssd是什么意思
- 汽车电子包含哪些领域?
- TWS蓝牙耳机是什么意思?你真的了解吗
- 什么是单片机?有什么用?
- 升压电路图汇总解析
- plc的工作原理是什么?
- 再次免费公开一肖一吗
- 充电桩一般是如何收费的?有哪些收费标准?
- ADC是什么?高精度ADC是什么意思?
- dtmb信号覆盖城市查询
- EDA是什么?有什么作用?
- 苹果手机哪几个支持无线充电的?
- type-c四根线接法图解
- 华为芯片为什么受制于美国?
- 怎样挑选路由器?
- 元宇宙概念股龙头一览
- 锂电池和铅酸电池哪个好?
- 什么是场效应管?它的作用是什么?
- 如何进行编码器的正确接线?接线方法介绍
- 虚短与虚断的概念介绍及区别
- 晶振的作用是什么?
- 大疆无人机的价格贵吗?大约在什么价位?
- 苹果nfc功能怎么复制门禁卡
- amoled屏幕和oled区别
- 单片机和嵌入式的区别是什么
- 复位电路的原理及作用
- BLDC电机技术分析
- dsp是什么意思?有什么作用?
- 苹果无线充电器怎么使用?
- iphone13promax电池容量是多少毫安
- 芯片的组成材料有什么
- 特斯拉充电桩充电是如何收费的?收费标准是什么?
- 直流电机驱动电路及原理图
- 传感器常见类型有哪些?
- 自举电路图
- 通讯隔离作用
- 苹果笔记本macbookpro18款与19款区别
- 新斯的指纹芯片供哪些客户
- 伺服电机是如何进行工作的?它的原理是什么?
- 无人机价钱多少?为什么说无人机烧钱?
- 以太网VPN技术概述
- 手机nfc功能打开好还是关闭好
- 十大公认音质好的无线蓝牙耳机
- 元宇宙概念龙头股一览