算法(TS):3的幂

给定一个整数,写一个函数来判断它是否是 3 的幂次方。如果是,返回 true ;否则,返回 false 。整数 n 是 3 的幂次方需满足:存在整数 x 使得 n == 3x

示例 1:

输入:n = 27

输出:true

示例 2:

输入:n = 0

输出:false

示例 3:

输入:n = 9

输出:true

示例 4:

输入:n = 45

输出:false

提示:

  • -231 <= n <= 231 - 1

进阶:你能不使用循环或者递归来完成本题吗?


解法一

判断 Math.pow(3,i) 是否等于 n ,i 从 0 递增到 i 的平方根。

typescript 复制代码
function isPowerOfThree(n: number): boolean {
    let result = false
    let i = 0
    const k = Math.sqrt(n)
    while(i < k) {
        if(Math.pow(3,i) === n) {
            return true
        }
        i++
    }
    return result
};

解法二

不断地将 n 除以 3,直到 n=1,如果在这个过程中遇到除不尽的情况,则说明 n 不是 3 的幂。

kotlin 复制代码
function isPowerOfThree(n: number): boolean {
    if(n<=0) return false
    while(n > 1) {
        if (n % 3 !== 0) {
            return false
        }

        n /=3
    }

    return true
};

解法三

在题目给定的 32 位有符号整数的范围内,最大的 3 的幂为 3^19 = 1162261467 。我们只需要判断 n 是否是 1162261467 的约数即可。

typescript 复制代码
function isPowerOfThree(n: number): boolean {
    return n > 0 && 1162261467 % n===0
};
相关推荐
浅念-2 分钟前
刷穿LeetCode:BFS 解决 Flood Fill 算法
数据结构·c++·算法·leetcode·职场和发展·bfs·宽度优先
做cv的小昊1 小时前
【TJU】研究生应用统计学课程笔记(8)——第四章 线性模型(4.1 一元线性回归分析)
笔记·线性代数·算法·数学建模·回归·线性回归·概率论
不会敲代码11 小时前
从零到一:用 Vue3 + Kimi 大模型打造「拍照记单词」AI 应用
vue.js·typescript·aigc
贾斯汀玛尔斯1 小时前
每天学一个算法--倒排索引(Inverted Index)
算法·inverted-index
小e说说1 小时前
打破偏科困境:这些学习软件助孩子重燃学习热情
算法
烛衔溟2 小时前
TypeScript 索引签名、只读数组与 keyof / typeof 入门
linux·ubuntu·typescript
月昤昽2 小时前
autoCAD二次开发 4.正多边形与collection区分
算法·c#·二次开发·autocad二次开发
休息一下接着来2 小时前
C++ 固定容量环形队列实现
c++·算法
im_AMBER3 小时前
手撕hot100之矩阵!看完这篇就AC~
javascript·数据结构·线性代数·算法·leetcode·矩阵
笨笨饿3 小时前
#79_NOP()嵌入式C语言中内联汇编宏的抽象封装模式研究
linux·c语言·网络·驱动开发·算法·硬件工程·个人开发