复制 输入: 6
输出: true
解释: 6 = 2 × 3
复制 输入: 8
输出: true
解释: 8 = 2 × 2 × 2
复制 输入: 14
输出: false
解释: 14 不是丑数,因为它包含了另外一个质因数 7。
回溯即可. 不停地除以2, 3, 5因子, 直到无法整除(回溯停止条件), 为1则为丑数, 不唯一说明有别的质数, 不是丑数.
复制 class Solution:
def isUgly(self, num: int) -> bool:
if num < 1:
return False
def is_ugly(number):
if number == 1:
return True
cond2, cond3, cond5 = False, False, False
if number % 2 == 0:
cond2 = is_ugly(number // 2)
if number % 3 == 0:
cond3 = is_ugly(number // 3)
if number % 5 == 0:
cond5 = is_ugly(number // 5)
return cond2 or cond3 or cond5
return is_ugly(num)
但递归的效率低, 原因是做了很多重复的除法计算. 例如6对2, 3可整除, 在2和3处都进行了递归, 算了两遍. 优化的方法是使用迭代, 整除完之后, 就判断结果是否为丑数即可.
复制 class Solution:
def isUgly(self, num: int) -> bool:
if num < 1:
return False
while num > 1:
if num % 2 == 0:
num //= 2
elif num % 3 == 0:
num //= 3
elif num % 5 == 0:
num //= 5
else:
return False
return True