326. Power of Three
EasyLeetCodeGiven an integer n, return true if it is a power of three. Otherwise, return false.
An integer n is a power of three, if there exists an integer x such that n == 3x.
Example 1:
Input: n = 27
Output: true
Explanation: 27 = 33
Example 2:
Input: n = 0
Output: false
Explanation: There is no x where 3x = 0.
Example 3:
Input: n = -1
Output: false
Explanation: There is no x where 3x = (-1).
Constraints:
-231 <= n <= 231 - 1
How to solve the problem
Using loop to check if n is divisible by 3, and if n/3 is also divisible by 3, and so on.
Using logrithm, if a number is a power of 3, then its log3(n) must be an integer. Combining the logarithmic base conversion formula: log3(n) = log10(n) / log10(3)
Code
- Loop
Python
class Solution:
def isPowerOfThree(self, n: int) -> bool:
if n <= 0: return False
while n > 1:
if n % 3 != 0: return False
n //= 3
return True
- Logarithm
Python
class Solution:
def isPowerOfThree(self, n: int) -> bool:
if n <= 0: return False
return (math.log10(n) / math.log10(3)).is_integer()
Complexity
Time complexity: O(log3(n))
Space complexity: O(1)
Comments
No comments yet. Be the first to comment!