Python | 动态规划解决“返回第n个丑数”
本文首发于微信公众号:"算法与编程之美",欢迎关注,及时了解更多此系列文章。
问题描述
给你一个整数 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 通常被视为丑数。
解决方案
解决本题要用到的是动态规划,同时要先知道什么是丑数,题目也很明确的说明了丑数是什么,接下来就是实现在代码方面找到丑数,对于找丑数可以使用python的一次循环遍历就可以得到需要的丑数,因为只存在2,3,5这三个元素,遍历过程中不会太复杂;知道了如何判断丑数后就是进一步的丑数的变形方式,本题所使用的动态规划并不是太复杂的动态规划,这里要用到的新的变量“指针”(p2,p3,p5)此处pi是可以与i相乘的最小丑数的位置,设置了三个指针后从最小的开始,指针的移动表示在从大到小的寻找丑数,nums[i]是由三个指针乘以相应的数得到的,把相对应的pi + 1表示没有乘过次nums的最小丑数变大了,然后一个数一个数的加进数组中,直到遍历结束。
具体代码如下:
n = int(input()) nums = [1]#放入第一个丑数1 p2 = 0# 三个初始化指针 p3 = 0 p5 = 0 for i in range(1, n):# 遍历n得到所有丑数 ushu = min(nums[p2] * 2, nums[p3] * 3, nums[p5] * 5)# 从小到大,按照丑数定义收集丑数 nums.append(ushu)# 将丑数放进结果数组中 if(nums[i] == nums[p2] * 2): p2 += 1# 指针移动,从小到大地寻找丑数 if(nums[i] == nums[p3] * 3): p3 += 1 if(nums[i] == nums[p5] * 5): p5 += 1 print(nums[n-1]) # 返回第n个丑数 |
运行效果:
结语
虽然是使用了动态规划的方式解决了本题,但对与动态规划还是处于模糊状态,还是会继续学习关于动态规划的知识,尽快熟悉并掌握运用,同时,做本题是要有一个清晰的思路,先得到什么,然后再做一步怎么样的操作。
实习编辑:李欣容
稿件来源:深度学习与文旅应用实验室(DLETA)
Python | 动态规划解决“返回第n个丑数”相关推荐
- python动态规划解决矩阵连乘
矩阵连乘:给定n个矩阵:A1,A2,...,An,其中Ai与Ai+1是可乘的,i=1,2...,n-1.确定计算矩阵连乘积的计算次序,使得依此次序计算矩阵连乘积需要的数乘次数最少.输入数据为矩阵个数和 ...
- 86. Leetcode 264. 丑数 II (动态规划-基础题)
给你一个整数 n ,请你找出并返回第 n 个 丑数 .丑数 就是只包含质因数 2.3 和/或 5 的正整数.示例 1:输入:n = 10 输出:12 解释:[1, 2, 3, 4, 5, 6, 8, ...
- 【数学】丑数II 和 超级丑数
题目描述 给你一个整数 n ,请你找出并返回第 n 个 丑数 . 丑数 就是只包含质因数 2.3 和/或 5 的正整数. 提示:1也是丑数 示例 1: 输入:n = 9 输出:10 解释:[1, 2, ...
- 【剑指offer-Java版】34丑数
丑数:返回第N个丑数 只包含因子 2 3 5的数称为丑数,第一个丑数是 1 采用辅助数组的方法,提高时间效率 – 下一个丑数一定是已有的丑数乘以2 或者 3 或者 5 得到的 public class ...
- AC日记——丑数 codevs 1246
1246 丑数 USACO 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 钻石 Diamond 题解 查看运行结果 题目描述 Description 对于一给定的素数集合 ...
- 78. Leetcode 264. 丑数 II (堆-技巧二-多路归并)
给你一个整数 n ,请你找出并返回第 n 个 丑数 .丑数 就是只包含质因数 2.3 和/或 5 的正整数.示例 1:输入:n = 10 输出:12 解释:[1, 2, 3, 4, 5, 6, 8, ...
- 【数据结构与算法】之深入解析“丑数II”的求解思路与算法示例
一.题目要求 给你一个整数 n ,请你找出并返回第 n 个丑数. 丑数就是只包含质因数 2.3 和(或) 5 的正整数. 示例 1: 输入:n = 10 输出:12 解释:[1, 2, 3, 4, 5 ...
- leetcode 264. 丑数 II(堆)
给你一个整数 n ,请你找出并返回第 n 个 丑数 . 丑数 就是只包含质因数 2.3 和/或 5 的正整数. 示例 1: 输入:n = 10 输出:12 解释:[1, 2, 3, 4, 5, 6, ...
- 剑指offer 面试题49. 丑数
我们把只包含因子 2.3 和 5 的数称作丑数(Ugly Number).求按从小到大的顺序的第 n 个丑数. 示例: 输入: n = 10 输出: 12 解释: 1, 2, 3, 4, 5, 6, ...
最新文章
- 各种经典透镜投影模型
- 我的微信'智障聊天助手'的设计思路
- PS想象的力量无限大,设计师的脑洞无限大!
- mybatis完整增删改查入门实例
- 接口测试工具postman(六)添加变量(参数化)
- 编写代码约定,每行字符长度不超过80列
- 【翻译】.NET 5 Preview8发布
- pycharm 更改创建文件默认路径
- Ubuntu安装Docker引擎和支持HTTPS的docker-registry服务
- 详解Java中ArrayList、Vector、LinkedList三者的异同点
- 面试题——股票利益最大化
- oracle自动分区maxvalue,对Maxvalue上限范围分区进行spilt操作
- Kafka从上手到实践-Zookeeper CLI:CRUD zNode | 凌云时刻
- GridView中使用DropDownList的OnSelectedIndexChanged事件
- 教你一秒无插件下载B站/MOOC课视频
- 如何解决注塑成型中的毛边问题?
- 在C语言中对于整形变量采用有符号数,C语言编程(张欣 机制192-3)-中国大学mooc-题库零氪...
- 合肥太阳能电池片表面缺陷检测-施努卡
- macappstore登不上去_Mac系统打不开appstore如何解决
- [10 Jun 2015 ~ 11 Jun 2015] Deep Learning in arxiv