丑数

2020-05-13  本文已影响0人  su945

题目描述

把只包含质因子2、3和5的数称作丑数(Ugly Number)。例如6、8都是丑数,但14不是,因为它包含质因子7。 习惯上我们把1当做是第一个丑数。求按从小到大的顺序的第N个丑数。

问题分析

我们把当前数组里面最大的ugly记为M,那么,下一个ugly肯定是前面的数与2或者3或者5的乘积中的最小值。然后我们拿这个最小值和M进行比较,如果小于M,就说明已经存在于数组中,如果大于M,则说明需要添加进数组。需要注意的是,我们每次判断之后,我们只需要第一个比M大的值,其他的以后会重新计算。程序中通过t2、t3、t5分别记录上次计算用到的ugly的相应序号。

解题思路1

class Solution {
public:
    int GetUglyNumber_Solution(int index) {
        if (index < 7)
        {
            return index;
        }
        vector<int> uglyArray(index);
        uglyArray[0] = 1;
        int t2 = 0;
        int t3 = 0;
        int t5 = 0;
        for (int i = 1; i < index; ++i)
        {
            uglyArray[i] = min(uglyArray[t2]*2,min(uglyArray[t3]*3,uglyArray[t5]*5));
            if(uglyArray[i] == uglyArray[t2]*2)
            {
                t2++;
            }
            if(uglyArray[i] == uglyArray[t3]*3)
            {
                t3++;
            }
            if(uglyArray[i] == uglyArray[t5]*5)
            {
                t5++;
            }
        }
        return uglyArray[index-1];

    }
};

上一篇 下一篇

猜你喜欢

热点阅读