算法(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 分钟前
深入了解linux系统—— 线程同步
linux·服务器·数据库·算法
数据爬坡ing5 分钟前
从挑西瓜到树回归:用生活智慧理解机器学习算法
数据结构·深度学习·算法·决策树·机器学习
luoganttcc6 分钟前
小鹏汽车 vla 算法最新进展和模型结构细节
人工智能·算法·汽车
wallflower20201 小时前
滑动窗口算法在前端开发中的探索与应用
前端·算法
林木辛1 小时前
LeetCode热题 42.接雨水
算法·leetcode
MicroTech20252 小时前
微算法科技(NASDAQ: MLGO)采用量子相位估计(QPE)方法,增强量子神经网络训练
大数据·算法·量子计算
星梦清河2 小时前
宋红康 JVM 笔记 Day15|垃圾回收相关算法
jvm·笔记·算法
货拉拉技术2 小时前
揭秘语音交互的核心技术
算法
矛取矛求2 小时前
日期类的实现
开发语言·c++·算法
在下雨5993 小时前
项目讲解1
开发语言·数据结构·c++·算法·单例模式