# -*- coding:utf-8 -*-
class Solution:
    def GetUglyNumber_Solution(self, index):
        # write code here
        if index<7:
            return index
        p1,p2,p3 = 0,0,0
        array = [1]
        while len(array)<index:
            newnum = min(array[p1]*2,array[p2]*3,array[p3]*5)
            array.append(newnum)
            if newnum == array[p1]*2:
                p1 += 1
            if newnum == array[p2]*3:
                p2 += 1
            if newnum == array[p3]*5:
                p3 +=1
        return array[-1]
在索引值小于7的时候,前6个丑数为1,2,3,4,5,6,我们设置起始数组为[1],后面的数依次是对于已知的丑数序列,后面的丑数一定是已知序列中的数字乘以2/3/5得到的。对当前序列中的数字乘2/3/5得到的数字中最小的数字才能放入序列。