# Power Of Three

Given 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

Example 2:

Input: n = 0

Output: false

Example 3:

Input: n = 9

Output: true

Example 4:

Input: n = 45

Output: false

# Approach:-

Firstly, since the input can be any negative integer also, we can directly return false as negative integers cannot be the power of three. In fact, any integer less than 1 cannot be a power of three. Now, we know that 1 is three raised to the power of 0. For any other number >1, we can keep on dividing our number by 3 and if at any step we find that the remainder is not 0, we can return false. Else, after reducing the number to 1, we return true.

```
class Solution {
public:
bool isPowerOfThree(int n) {
if(n<1) // all negative numbers and 0 can't be a power of 3
return false;
if(n==1) // 1 is a power of 3
return true;
while(n>1){
int remainder=n%3; // taking out remainder of n after dividing by 3
// if remainder is not 0, the number can't be a power of 3
// since it is not divisble by 3
if(remainder!=0)
return false;
n/=3; // dividing n by 3 if remainder is 0
}
return true;
}
};
```

Time Complexity: O(log3(n))

Space Complexity: O(1)

# Alternative Solution:-

```
class Solution {
public:
bool isPowerOfThree(int n) {
return n>0 && 1162261467%n==0;
}
};
```

Since for all power of 3,

9%3 == 27%3==27%9==81%27==0, this relation is followed.

1162261467 is the highest possible power of 3 that can be contained in a 32-bit integer, any number for being a power of 3 must-have 1162261467%n==0.

Time Complexity: O(1)

Space Complexity: O(1)