leetcode263.丑数

124 阅读1分钟

263.丑数

编写一个程序判断给定的数是否为丑数。丑数:只包含质因数 2, 3, 5正整数

输入: 6
输出: true
解释: 6 = 2 × 3
输入: 14
输出: false 
解释: 14 不是丑数,因为它包含了另外一个质因数 7。
  1. 1 是丑数。
  2. 输入不会超过 32 位有符号整数的范围: [−2^31, 2^31 − 1]。
class Solution:
    def isUgly(self, num: int) -> bool:
        if num <= 0:
            return False
        for x in [2, 3, 5]:
            while num % x == 0:
                num //= x
        return num == 1
"""
将输入数重复除以2, 3, 5,判断得数是否为1即可
如果若干次操作后,num变成1,说明num的因数只有2、3、5,是丑数
"""