丑数

时间限制:C/C++ 1秒,其他语言2秒 空间限制:C/C++ 32M,其他语言64M 

题目描述

把只包含质因子2、3和5的数称作丑数(Ugly Number)。例如6、8都是丑数,但14不是,因为它包含质因子7。 习惯上我们把1当做是第一个丑数。求按从小到大的顺序的第N个丑数。
 
思路:
  采用穷举的方式,先依次找到从小到大的丑数,并存入列表中:
    丑数的是只包含质因子2、3、5的,1是第一个丑数,设置三个列表指针index2、index3、index4分别指向2、3、5,选取这三者当前指针指向最小的丑数并存入vector<int>容器中,除此之外,还需要对当前最小丑数的指针进行加1操作。
  最后输出vector容器最后一个元素即为所求
class Solution {
public:
    int GetUglyNumber_Solution(int index) {
        if(index < 7)
            return index;
        vector<int> res(index);
        res[0] = 1;
        int index2 = 0;
        int index3 = 0;
        int index4 = 0;
        for(int i = 1;i < index;i++)
        {
            int val = min(res[index2]*2,min(res[index3]*3,res[index4]*5));
            if(val == res[index2] * 2)
            {
                index2++;
            }
             if(val == res[index3] * 3)
            {
                index3++;
            }
             if(val == res[index4] * 5)
            {
                index4++;
            }
            res[i] = val;
        }
        return res[index-1];
    }
};

 附上关于std::min函数的介绍:

posted @ 2020-03-29 11:17  牛犁heart  阅读(196)  评论(0编辑  收藏  举报