Power of Three

Problem

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
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

Follow up: Could you solve it without loops/recursion?

Solution

class Solution {
    public boolean isPowerOfThree(int n) {
        if (n == 0) {
            return false;
        }
        while (n % 3 == 0) {
            n = n / 3;
        }
        return n == 1;
    }
}

Recent posts from blogs that I like

Painting Pandora and her box: 1883-1919

Suddenly popular in paintings from around 1880, the story of Pandora and her box brought many interpretations, and remains a story of our time.

via The Eclectic Light Company

some things I've learned about dealing with people

:)

via bookbear express

DeepSeek V4 - almost on the frontier, a fraction of the price

via Simon Willison