3的幂,给定一个整数,写一个函数来判断它是否是 3 的幂次方。如果是,返回 true ;否则,返回 false。

题记:

给定一个整数,写一个函数来判断它是否是 3 的幂次方。如果是,返回 true ;否则,返回 false 。

整数 n 是 3 的幂次方需满足:存在整数 x 使得 n == 3^x

示例 1:

输入:n = 27
输出:true

示例 2:

输入:n = 0
输出:false

示例 3:

输入:n = 9
输出:true

示例 4:

输入:n = 45
输出:false

提示:

-2 ^ 31 <= n <= 2 ^ 31 - 1

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

题目来源:
作者:LeetCode
链接:https://leetcode.cn/leetbook/read/top-interview-questions-easy/xnsdi2/
来源:力扣(LeetCode)

解题方法:

自己敲的:

一:循环,一直乘以3,判断是否有等于该整数的数存在

function isPowerOfThree($n) {//循环if($n == 3 || $n == 1)return true;$start = 3;while($start && $start <= $n){$start = $start * 3;if($start == $n){return true;}}return false;
}

二:递归,一直除以3

function isPowerOfThree($n) {//递归if($n == 1)return true;if($n > 0 && $n % 3 == 0 && $this->isPowerOfThree($n / 3))return true;return false;
}

官方方法:(其实也就是一直乘以3)

function isPowerOfThree($n) {$flag = true;$num  = 0;while($flag){$x = pow(3,$num);	//3的num次方$num++;if($x > $n){$flag = false;return false;}  if($x == $n){$flag = false;return true;} }   
}

其他方法:

一:一直除以3

一种最简单的方式就是判断n是否能够被3整除,如果能够被3整除就除以3,直到不能被3整除为止,最后判断n是否等于1,代码比较简单,来看下

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

转换为PHP代码为:

function isPowerOfThree($n) {//一直除以3if($n > 1){while($n % 3 == 0){$n /= 3;}}return $n == 1; 
}

二:递归方式解决(同上面的递归方法,只是简化了写法)

还可以改为递归的方式,一行代码解决

public boolean isPowerOfThree(int n) {return n > 0 && (n == 1 || (n % 3 == 0 && isPowerOfThree(n / 3)));
}

转换为PHP代码为:

function isPowerOfThree($n) {return $n > 0 && ($n == 1 || ($n % 3 == 0 && $this->isPowerOfThree($n / 3))); 
}

三:算术表达式计算

先来普及一波数学知识

对数的乘法法则: log(ab) = log(a) + log(b)
对数的乘法法则表明,两个数相乘的对数等于这两个数分别对数后的和。例如,log(10100) = log(10) + log(100) = 1 + 2 = 3。

对数的除法法则: log(a/b) = log(a) - log(b)
对数的除法法则表明,两个数相除的对数等于这两个数分别对数后的差。例如,log(100/10) = log(100) - log(10) =
2 - 1 = 1。

对数的幂法法则: log(a^b) = blog(a)
对数的幂法法则表明,一个数的幂的对数等于这个数的对数乘以幂的指数。例如,log(10^3) = 3log(10) = 3*1 = 3。

对数的换底公式: loga(b) = logc(b)/logc(a)
对数的换底公式表明,任意两个底不同的对数可以用一个公共底的对数来表示。例如,log2(8) = log10(8)/log10(2) =
0.903/0.301 = 3。

public boolean isPowerOfThree(int n) {return (Math.log10(n) / Math.log10(3)) % 1 == 0;	//对照对数的换底公式//log3(n)
}

四:找到最大幂

题中n的范围是 -2^31 <= n <= 2^31 - 1 ,而在这个范围内3的最大幂是1162261467,在比他大就超过int表示的范围了,我们直接用它对n求余即可,过求余的结果是0,说明n是3的幂次方

public boolean isPowerOfThree(int n) {return (n > 0 && 1162261467 % n == 0);
}

转换为PHP代码为:

function isPowerOfThree($n) {return ($n > 0 && 1162261467 % $n == 0); 
}

方法来源:
作者:数据结构和算法
链接:https://leetcode.cn/leetbook/read/top-interview-questions-easy/xnsdi2/?discussion=xhUFcs
来源:力扣(LeetCode)

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/10910.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

四元数

public static Quaternion Euler(Vector3 euler); 传入一个向量&#xff0c;使物体旋转&#xff0c;如&#xff1a; cube.transform.rotationQuaternion.Euler(new Vector3(0,30,0)); 值得注意的是&#xff1a;Unity中组件Transform的Rotation实际上是Quaternion类型的 publ…

【雕爷学编程】MicroPython动手做(02)——尝试搭建K210开发板的IDE环境

知识点&#xff1a;简单了解K210芯片 2018年9月6日,嘉楠科技推出自主设计研发的全球首款基于RISC-V的量产商用边缘智能计算芯片勘智K210。该芯片依托于完全自主研发的AI神经网络加速器KPU,具备自主IP、视听兼具与可编程能力三大特点,能够充分适配多个业务场景的需求。作为嘉楠科…

详解Mybatis之动态sql问题

编译软件&#xff1a;IntelliJ IDEA 2019.2.4 x64 操作系统&#xff1a;win10 x64 位 家庭版 Maven版本&#xff1a;apache-maven-3.6.3 Mybatis版本&#xff1a;3.5.6 文章目录 一. 在sql映射文件中如何写注释&#xff1f;二. 什么是动态sql&#xff1f;三. 动态sql常用标签有…

Android Studio 中使用 FlutterJsonBeanFactory

1、创建entity 安装FlutterJsonBeanFactory插件&#xff0c;在文件夹下右键 New -> JsonDartBeanAction 2、删除entity&#xff0c;直接右键删除entity&#xff0c;然后到generated/json/base/json_convert_content.dart文件&#xff0c;按下快捷键altj即可 参考文章 ht…

VBA操作WORD(六)另存为不含宏的文档

Sub 另存为不含宏的文档()Application.DisplayAlerts False Application.ScreenUpdating FalseDim oDoc As DocumentSet oDoc Word.ActiveDocumentDim oRng As RangeSet oRng oDoc.ContentDim sPath As String默认存储路径&#xff0c;当前用户桌面&#xff0c;注释掉的是当…

pycharm 使用远程服务器 jupyter (本地jupyter同理)

1. 远程服务器miniconda 环境中创建jupyter环境 # 1. 激活环境 conda activate envname#2. 在环境中安装jupyter pip install jupyter # 或者 conda install jupyter#3. 生成jupyter_notebook_config.py文件 jupyter notebook --generate-config#4. 设置密码 jupyter noteboo…

Spark编程-SparkSQL

SparkSql能做些啥 Spark SQL的核心概念是DataFrame&#xff0c;它是一个分布式的数据集合&#xff0c;类似于关系数据库中的表。支持使用SQL语言直接对DataFrame进行查询,提供了丰富的内置函数和表达式&#xff0c;可以用于数据的转换、过滤和聚合等操作,支持多种数据源&#…

功能测试也可以发现数据库相关的性能问题

很多同学认为功能测试和性能测试是严格分开的&#xff0c;功能测试人员无法发现性能问题。其实不是这样的&#xff0c;功能测试人员在验证功能时也可以发现性能问题&#xff1b;一些功能反而在功能测试环境不好验证&#xff0c;需要在性能环境上测试。 今天咱们就说一下测试涉及…

Leetcode 滑动窗口题目总结

(Leetcode 滑动窗口题目总结) 1&#xff1a; 3.无重复字符的最长子串 https://leetcode.cn/problems/longest-substring-without-repeating-characters/description/子串 和 子序列的区别&#xff1a;字串是连续的&#xff0c;子序列是非连续的。快慢指针 i 和 j&#xff0c;…

前端面试题 —— React (二)

目录 一、React 组件中怎么做事件代理&#xff1f;它的原理是什么&#xff1f; 二、React.Component 和 React.PureComponent 的区别 三、Component, Element, Instance 之间有什么区别和联系&#xff1f; 四、React声明组件有哪几种方法&#xff0c;有什么不同&#xff1f…

QT项目代码去UI界面常用开发步骤

QT项目代码去UI界面常用开发步骤 因项目开发需求&#xff0c;领导要求整个QT项目中不要用UI方式来实现界面&#xff0c;这样能保障程序运行稳定性以及代码的逻辑和可读性,先记录具体操作步骤如下&#xff1a; 1、首先我们通过拖控件的方式来实现界面的设计效果&#xff0c…

【Docker】安全及日志管理

目录 一、Docker 安全及日志管理1.1 Docker 容器与虚拟机的区别1. 隔离与共享2. 性能与损耗 1.2Docker 存在的安全问题1.Docker 自身漏洞2.Docker 源码问题 1.3 Docker 架构缺陷与安全机制1. 容器之间的局域网攻击2. DDoS 攻击耗尽资源3. 有漏洞的系统调用4. 共享root用户权限 …

DEVICENET转ETHERNET/IP网关devicenet协议

捷米JM-EIP-DNT&#xff0c;你听说过吗&#xff1f;这是一款自主研发的ETHERNET/IP从站功能的通讯网关&#xff0c;它能够连接DEVICENET总线和ETHERNET/IP网络&#xff0c;从而解决生产管理系统中协议不同造成的数据交换互通问题。 这款产品在工业自动化领域可谓是一大利器&…

特定Adreno GPU的Android设备发生冻屏问题

1&#xff09;特定Adreno GPU的Android设备发生冻屏问题 ​2&#xff09;Unity版本升级后&#xff0c;iOS加载UnityFramework bundle闪退 3&#xff09;关于RectTransfrom.rect在屏幕空间中表示的相关问题 4&#xff09;Unity Mesh泄露问题 这是第345篇UWA技术知识分享的推送&a…

Java 8 Stream流:代码简洁之道

文章目录 前言一、filter二、map三、mapToInt、mapToLong、mapToDouble四、flatMap五、flatMapToInt、flatMapToLong、flatMapToDouble六、distinct七、sorted八、peek九、limit十、forEach十一、forEachOrdered十二、toArray十三、reduce十四、collect十五、min、max十六、cou…

uniApp禁止遮罩弹窗下的页面滚动

文章目录 问题解决代码 问题 最近用uniApp开发一款软件&#xff0c;页面是可以滚动的长列表&#xff0c;自定义组件弹窗遮罩出来后&#xff0c;滑动屏幕&#xff0c;页面也跟着滚动。研究了网上的解决办法 在遮罩层的最外层的view元素中加入 touchmove.stop.prevent"moveH…

Llama 2 来袭 - 在 Hugging Face 上玩转它

&#x1f917; 宝子们可以戳 阅读原文 查看文中所有的外部链接哟&#xff01; 引言 今天&#xff0c;Meta 发布了 Llama 2&#xff0c;其包含了一系列最先进的开放大语言模型&#xff0c;我们很高兴能够将其全面集成入 Hugging Face&#xff0c;并全力支持其发布。Llama 2 的社…

Apache Kafka 入门教程

Apache Kafka 入门教程 一、简介简介架构 二、Kafka 安装和配置JDK安装 Kafka配置文件详解 三、Kafka 的基本操作启动和关闭Topic 创建和删除Partitions 和 Replication 配置Producer 和 Consumer 使用方法ProducerConsumer 四、Kafka 高级应用消息的可靠性保证Kafka StreamKaf…

Last Week in Milvus

Whats New 全力冲刺2.3.0发布中 Core Updates #25663 删除了 calc_distance 接口。此接口用于计算输入的向量之间的距离&#xff0c;但由于使用用户较少&#xff0c;且维护成本较高&#xff0c;会在2.3.0中将其删除。 #25031 大量用户反馈在standalone模式下&#xff0c;系统空…

将AWS S3大文件文件上传相关的API集成为js文件,功能包括 多文件并行上传、文件分片上传、断点续传、文件分片合成、上传暂停、取消上传、文件上传进度条显示

地址 https://github.com/gk-1213/easy-s3/tree/main easy-s3 将AWS S3大文件文件上传相关的API集成为js文件&#xff0c;功能包括多文件并行上传、文件分片上传、断点续传、文件分片合成、上传暂停、取消上传、文件上传进度条显示。 暂时不包括文件分片下载相关功能&#…