题解 | #丑数#

丑数

http://www.nowcoder.com/practice/6aa9e04fc3794f68acf8778237ba065b

思路:
知道这个就很好做了:每个正整数都能够以唯一的方式表示成它的质因数的乘积。
即,2,3,5几个数字的乘积

class Solution:
    def GetUglyNumber_Solution(self, index):
        # write code here
        dp = [1]*index
        if index<=0:
            return 0
        p2,p3,p5 = 0,0,0
        for i in range(1,index):
            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[index-1]
全部评论

相关推荐

04-29 22:35
门头沟学院 Java
牛友说改了名字能收到offer:旧图新发查看图片
点赞 评论 收藏
分享
强大的马里奥:不太可能,我校计算机硕士就业率99%
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务