263. 丑数
编写一个程序判断给定的数是否为丑数。
丑数就是只包含质因数 2, 3, 5 的正整数。
- 示例 1:
输入: 6
输出: true
解释: 6 = 2 × 3
- 示例 2:
输入: 8
输出: true
解释: 8 = 2 × 2 × 2
- 示例 3:
输入: 14
输出: false
解释: 14 不是丑数,因为它包含了另外一个质因数 7。
说明:
1 是丑数。
输入不会超过 32 位有符号整数的范围: [−231, 231 − 1]。
链接:https://leetcode-cn.com/problems/ugly-number
题解:
- 仅被2,3,5整除,最后结果为1,如果不是1的则不是丑数
- 被测数字范围 [−231, 231 − 1],其中小于0的0,负数直接排除
- 枚举出 N%5,N%3,N%2, 这3中情况下能否整除,直接使用模判断为0不行,因为 7%2=3,3%3==0;实际上还需要迭代除法判断;
4/2 = 2, 2/2 = 1,7/3 =2.34 - 这时候可以使用循环和递归,但循环比递归效率高
class Solution:
def isUgly(self, num):
if num < 1:
return False
while num!=1:
if num % 5 == 0:
num /= 5
elif num % 3 == 0:
num /= 3
elif num % 2 == 0:
num /= 2
else:
return False
return True