【LeetCode每日一题】——264.丑数 II

news2024/11/17 5:21:58

文章目录

  • 一【题目类别】
  • 二【题目难度】
  • 三【题目编号】
  • 四【题目描述】
  • 五【题目示例】
  • 六【解题思路】
  • 七【题目提示】
  • 八【时间频度】
  • 九【代码实现】
  • 十【提交结果】

一【题目类别】

  • 动态规划

二【题目难度】

  • 中等

三【题目编号】

  • 264.丑数 II

四【题目描述】

  • 给你一个整数 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 通常被视为丑数。

六【解题思路】

  • 如果判断每一个数字是否是丑数,肯定会超时,所以应该使用题目给的条件,生成丑数,这就用到了动态规划的知识
  • 由于第一个丑数我们是知道的,应该是1,那么就利用1来生成剩余的丑数
  • 因为丑数只包含2、3、5,所以用丑数乘这几个数还是丑数,那么究竟乘哪个呢?肯定每次都要取乘完之后最小的
  • 所以定义三个指针,分别表示三个丑数因数该乘哪个丑数了
  • 这样每次都用没乘过2或3或5的最小丑数,乘2或3或5,就可以得到新的丑数,所以动态转移方程为: d p [ i ] = m i n ( d p [ p 2 ] ∗ 2 , d p [ p 3 ] ∗ 3 , d p [ p 5 ] ∗ 5 ) dp[i] = min(dp[p2] * 2,dp[p3] * 3,dp[p5] * 5) dp[i]=min(dp[p2]2,dp[p3]3,dp[p5]5)
  • 还要注意,每次乘完2或3或5后,对应的指针应该后移,表示当前已经得到一个最小的丑数了,应该去比较下一个丑数与2或3或5相乘会不会得到最小丑数
  • 最后返回结果即可

七【题目提示】

  • 1 < = n < = 1690 1 <= n <= 1690 1<=n<=1690

八【时间频度】

  • 时间复杂度: O ( n ) O(n) O(n),其中 n n n为传入参数大小
  • 空间复杂度: O ( n ) O(n) O(n),其中 n n n为传入参数大小

九【代码实现】

  1. Java语言版
class Solution {
    public int nthUglyNumber(int n) {
        int[] dp = new int[n + 1];
        dp[1] = 1;
        int p2 = 1;
        int p3 = 1;
        int p5 = 1;
        for(int i = 2;i<=n;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. C语言版
int nthUglyNumber(int n)
{
    int* dp = (int*)malloc(sizeof(int) * (n + 1));
    dp[1] = 1;
    int p2 = 1;
    int p3 = 1;
    int p5 = 1;
    for(int i = 2;i<=n;i++)
    {
        dp[i] = fmin(dp[p2] * 2,fmin(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. Python版
class Solution:
    def nthUglyNumber(self, n: int) -> int:
        dp = [1] * (n + 1)
        p2 = 1
        p3 = 1
        p5 = 1
        for i in range(2,n+1):
            dp[i] = min(dp[p2] * 2,dp[p3] * 3,dp[p5] * 5)
            if dp[i] == dp[p2] * 2:
                p2 += 1
            if dp[i] == dp[p3] * 3:
                p3 += 1
            if dp[i] == dp[p5] * 5:
                p5 += 1
        return dp[n]

十【提交结果】

  1. Java语言版
    在这里插入图片描述

  2. C语言版
    在这里插入图片描述

  3. Python语言版
    在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/107727.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

React DAY06

复习&#xff1a; 1.React是一个用于构建用户界面的JS库——不涉及HTML/CSS。可用于创建PC网站、H5、WebApp、NativeApp。2013年中Facebook开源&#xff0c;目前最新版V18.2。 主要知识点&#xff1a; ①使用React的两种方法&#xff1a;脚本引入式、脚手架方式(create-react-…

VUE部署至Nginx

VUE部署至Nginx安装Nginx解压Nginx配置VUE文件配置Nginx启动Nginx快速停止或关闭nginx正常停止或关闭nginx配置文件nginx.conf修改重装载命令安装Nginx 网址&#xff1a;https://nginx.org/en/download.html 选择图中红框下载安装 解压Nginx 只需要解压到目录&#xff0c;无…

GitHub典藏版,腾讯T14级高级程序员亲码的分布式数据库实践,再次爆火

数据库就是要做好五件事&#xff0c;存储、事务、查询、复制和其他。而对分布式数据库来说&#xff0c;不仅要继续做这五件事&#xff0c;还要多出一件事&#xff0c;分片。在这六件事中&#xff0c;存储和其他这两件事与单体数据库差不多&#xff0c;难点就在事务、查询、复制…

论文复现丨基于ModelArts进行图像风格化绘画

摘要&#xff1a;这个 notebook 基于论文「Stylized Neural Painting, arXiv:2011.08114.」提供了最基本的「图片生成绘画」变换的可复现例子。本文分享自华为云社区《基于ModelArts进行图像风格化绘画》&#xff0c;作者&#xff1a; HWCloudAI 。 项目首页 | GitHub | 论文 …

敏捷、分散式的数据治理,该如何实现?

01 数据资产的生产和消费现状 —— 孤岛就在那里&#xff01; 在大数据时代&#xff0c;企业数据资产的生产和消费&#xff0c;实际现状大概是这样的。 一方面&#xff0c;每个业务部门都产生并存储了大量的数据。这些数据存储在不同的系统中。每个业务部门都是数据的生产者…

安卓逆向-某音乐软件

初学安卓逆向&#xff0c;如有错误请指教 某我音乐9.3.4.4版本&#xff0c;需要资源的请流言&#xff08;也可以自行去下载&#xff09; 直接将apk拖入到AndroidKiller里面(该工具自行下载) 首先去除广告 直接全局搜索KEY_EXTRA_AUTH&#xff0c;可以只在.smali文件里面搜索…

【gitlab wiki】git首次上传本地文档操作步骤

1.在gitLab中创建一个项目 2.进入本地电脑中的你要上传文件的文件目录&#xff0c;右击鼠标选择“ Git Bash Here” git命令窗口(本机电脑要安装好git) 3.在远程git项目中&#xff0c;复制出项目http地址。 4.在“ Git Bash Here” git命令窗口输入命令&#xff1a;git clone h…

Java+MYSQL基于ssm的网上出差审批与费用报销管理系统

全新的时代,新的技术推动着公司管理制度的改革,在管理层面加入了先进的科学技术做到了与时俱进,所以企业创建自己的网上出差审批与费用报销系统是迫切需要的。在新时代的背景下,传统管理方式的缺点被暴露出来,传统管理方式的不足的地方有管理及时性不够,下达一个指令以后需要层…

AuthLab权限在线靶场通关记录

AuthLab通关记录 一个在线的权限靶场&#xff1a;https://authlab.digi.ninja/ 靶场内容比较简单&#xff0c;包括了JWT以及一些基本情况的权限Bypass IP Based Auth Bypass 该关卡根据提示有一个ip在192.168.0.100-200范围里可以直接bypass 拦截请求包修改X-Forwarded-For爆…

python网络副业有哪些?以自身经历分享怎么做副业挣钱

网络副业我个人比较看好的是Python&#xff0c;至少我是真实体会到了Python做副业真香&#xff0c;疫情被关在家那段时间也没耽误赚钱&#xff0c;反而比平常赚的还多一点&#xff0c;下图是我疫情期间在家做Python副业收入的部分截图&#xff0c;那会儿我用Excel表格每天记了一…

BEPU物理引擎碰撞系统的架构与设计

前面我们讲解了如何监听物理引擎的碰撞事件, 在物理引擎内核中如何架构与设计碰撞规则,使得物理Entity与周围的物理环境产生碰撞时&#xff0c;如何灵活的控制物理碰撞&#xff0c;本节給大家详细的讲解BEPUphysicsint 物理引擎内部是如何管理与控制碰撞规则的。本文主要讲解3个…

彻底删除的文件如何恢复?误删数据恢复,四种方法就可以解决

电脑磁盘中存储了许多文件&#xff0c;我们不可避免地会误删一些文件&#xff0c;但是我们中的许多人不知道在文件被错误删除后如何恢复它们。事实上&#xff0c;误删数据恢复没有想象中那么难&#xff0c;我们自己也可以操作完成。到底是什么方法&#xff1f;接下来我们将详细…

Java项目:springboot中小医院信息管理系统

作者主页&#xff1a;源码空间站2022 简介&#xff1a;Java领域优质创作者、Java项目、学习资料、技术互助 文末获取源码 项目介绍 1. 基于SpringBoot的中小医院信息管理系统&#xff0c;实现了部分核心功能。 2. 就诊卡提供了手动和读卡两种方式录入&#xff0c;其中IC读卡器…

Simulink 自动代码生成电机控制:基于霍尔FOC模型和代码生成

目录 霍尔角度估算原理 霍尔角度估算FOC模型和仿真 代码生成软件调试 总结 霍尔角度估算原理 PMSM在定子侧以互差120电角度的位置安装3个霍尔元件Ha, Hb, Hc。当转子转动时&#xff0c;霍尔元件会产生3个相位差120电角度的高低电平信号。霍尔信号会将一个电周期划分为6个扇…

可以快速搭建的免费开源项目:直播带货、富文本笔记、思维导图、声音克隆、消息推送服务、文档协作等等

可以快速搭建的免费开源项目&#xff1a;直播带货、富文本笔记、思维导图、声音克隆、消息推送服务、文档协作等等。 01 Pure Live 一个想让直播回归纯粹的项目&#xff0c;没有礼物、粉丝团、弹窗&#xff0c;只有直播和弹幕。这是国人在GitHub上制作的一个开源的直播系统&am…

一个转行者的自述,大学生做职业规划要趁早

这篇文章写给对自己的职业规划不清晰、想从第一份工作就找准职业方向的应届大学生。 作为21年毕业的职场新人&#xff0c;算不上建议&#xff0c;也不写鸡汤&#xff0c;只是在这里认真分享我走过的弯路。文章略长&#xff0c;预计阅读时间8分钟。 先说一个关于海的小故事 人们…

CSS -- CSS使用过渡(transition)添加动画

CSS 3过渡 过渡&#xff08;transition)是CSS3中具有颠覆性的特征之一&#xff0c;我们可以在不使用 Flash 动画或JavaScript 的情况下&#xff0c;当元素从一种样式变换为另一种样式时为元素添加效果。 过渡动画&#xff1a; 是从一个状态 渐渐的过渡到另外一个状态 可以让…

js什么是闭包?简单理解

闭包 作用域链和执行上下文 理解闭包前&#xff0c;先引入一个概念&#xff0c;作用域链 用我自己理解的讲&#xff1a;在一段程序中&#xff0c;程序内的变量、函数等都被串在这条链上&#xff0c;当我们使用这些变量、函数时&#xff0c;程序就会在这条链中搜索&#xff0…

【最新】滤器完整性检测各国规定

中国 用于直接接触无菌药液或无菌设备表面的气体的过滤器&#xff0c;应在每批或多批次连续生产结束后对其进行完整性测试。对于其他的应用&#xff0c;可以根据风险评估的结果&#xff0c;制定完整性测试的频率。 ——除菌过滤技术与应用指南 2018 美国 We recommend that …

系统中的安全架构

系统中的安全架构目录概述需求&#xff1a;设计思路实现思路分析1.shiro2.多模块下的安全架构参考资料和推荐阅读Survive by day and develop by night. talk for import biz , show your perfect code,full busy&#xff0c;skip hardness,make a better result,wait for chan…