264. 丑数 II

编写一个程序,找出第 n 个丑数。

丑数就是只包含质因数 2, 3, 5 的正整数。

示例:

输入: n = 10
输出: 12
解释: 1, 2, 3, 4, 5, 6, 8, 9, 10, 12 是前 10 个丑数。
说明:

1 是丑数。
n 不超过1690。


image.png
分析:除了第一个丑数1以外 每一个丑数都是 由 2,3,5,
 乘以原有的丑数集合{1。。。。},来扩充,
注意一点,在该题目中每次扩充一位即可,
每次都要比较,(2,3,5)所乘得到的数,
选择最小的数
(,加入丑数集合中,此时,将刚刚被乘以的那个(
2,3,5)去乘以,集合中的下一个数
(可能会相等,此时那相等的数,同时乘以集合的下一个)。



(2,3,5)每个都数都要乘以丑数数组中的每一个数,
设每个(2,3,5)都有一个指针(都在遍历丑数数组),
当乘以丑数数组的积为最小时
(若相等,指针都会指向下一个),
指针指向下一个,依次类推。

*/
class Solution {
    public int nthUglyNumber(int n) {
        
        
        int [] res = new int[n];
       res[0] = 1;
        int i2 = 0, i3 = 0, i5 = 0,k = 0;
        for( k = 1;k<n;k++) {
            int m2 = res[i2] * 2, m3 = res[i3] * 3, m5 = res[i5] * 5;
            int mn = Math.min(m2, Math.min(m3, m5));
            if (mn == m2) ++i2;
            if (mn == m3) ++i3;
            if (mn == m5) ++i5;
            res[k] = mn;
        }
        return res[k-1];
        
        
    }
}

leetcode 原题

©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • 在C语言中,五种基本数据类型存储空间长度的排列顺序是: A)char B)char=int<=float C)ch...
    夏天再来阅读 4,090评论 0 2
  • 第一章数和数的运算 一概念 (一)整数 1整数的意义 自然数和0都是整数。 2自然数 我们在数物体的时候,用来表示...
    meychang阅读 2,851评论 0 5
  • 闯进我生活里的人很多 能留在我心底的人也有很多 可能不断出现在我梦中的 唯有你一个 我以为这辈子的梦 都只会是你一...
    单人路途阅读 370评论 0 0
  • 没有行动,懒惰就会生根发芽! 没有梦想,堕落就会生根发芽! 时间越长,根就越来越深! 到时候想站起来就会是件很困难...
    简单的就好了阅读 306评论 0 1
  • This is my room,it's small but tidy. Can you see my clock...
    小米0410阅读 411评论 0 2

友情链接更多精彩内容