判断一个数字是否可以表示成三的幂的和(难度:中等)

简介: 判断一个数字是否可以表示成三的幂的和(难度:中等)

题目描述:

给你一个整数 n ,如果你可以将 n 表示成若干个不同的三的幂之和,请你返回 true ,否则请返回 false

对于一个整数 y ,如果存在整数 x 满足 y == 3x ,我们称这个整数 y 是三的幂。

示例 1:

输入:n = 12
输出:true
解释:12 = 3^1 + 3^2

示例 2:

输入:n = 91
输出:true
解释:91 = 3^0 + 3^2 + 3^4

示例 3:

输入:n = 21
输出:false

提示:

  • 1 <= n <= 10^7

解法:贪心+递归

根据题目意思,我们可以通过递归的思想,不断的减小n,直到其小于3,可以很快的判断是否满足题目意思。

使用贪心思路,每次找到不大于 n 的最大3的幂temp,让n减去temp再进行下一轮递归。

边界条件:

  • 若 n >= 2 * temp,即下一轮递归,找到不大于 n 的最大3的幂还是temp,不满足题目条件。
  • 若 n < 3 时,如果 n == 0 或者 n == 1,则满足条件。

class Solution {
    public boolean checkPowersOfThree(int n) {
        // 若剩余大小n小于3,如果是0 或者 3^0 则满足条件
        if (n < 3) {
            return n == 0 || n == 1;
        }
        int temp = 1;
        //找到不大于 n 的最大3的幂
        while (temp * 3 <= n) {
            temp *= 3;
        }
        //因为每一个三的幂只能有一个,若剩余数仍然大于temp,那么必定还需要一个temp
        if (n >= temp * 2) {
            return false;
        }
        return checkPowersOfThree(n - temp);
    }
}



相关文章
|
监控 Java 应用服务中间件
网关大解密:探索Spring Cloud Alibaba中Gateway的奥秘
网关大解密:探索Spring Cloud Alibaba中Gateway的奥秘
685 1
一篇文章总结氚云函数
氚云函数包含 14类数学函数类型 12类文本函数类型 17类时间函数类型 3类逻辑函数和2类其他函数
一篇文章总结氚云函数
|
弹性计算 关系型数据库 应用服务中间件
从零基础到博主大亨!一键解锁阿里云ECS,LNMP秒搭WordPress,你的个性博文帝国,今日崛起!
【8月更文挑战第5天】随着互联网技术的发展,个人博客成为技术爱好者和内容创作者分享知识的平台。阿里云ECS以其高性能和灵活性成为搭建博客的优选。本文指导你购买配置ECS,并安装CentOS 7。通过SSH登录后,更新系统并安装LNMP环境,包括Nginx、MariaDB、PHP。配置Nginx处理PHP请求,初始化数据库并设置WordPress数据库。接着下载WordPress,解压并设置权限。最后,通过浏览器完成安装向导。利用WordPress丰富的资源定制网站,开启个性化创作之旅。记得定期备份数据,利用ECS的扩展性支持网站成长。
235 4
|
数据采集 人工智能 安全
AI项目高昂成本与数据问题阻碍进展,2025年前30%的GenAI项目或将搁浅
AI项目高昂成本与数据问题阻碍进展,2025年前30%的GenAI项目或将搁浅
|
机器学习/深度学习 人工智能 自然语言处理
【热门话题】如何通过AI技术提升内容生产的效率与质量
本文探讨AI技术如何提升内容生产的效率与质量。通过自然语言处理(NLP)实现智能摘要、自动写作和语言风格优化;计算机视觉用于图像识别和智能设计,提升视频与图像内容生产;数据分析与预测帮助精准洞察受众需求和预测内容趋势;AI推荐系统实现个性化信息流,优化用户体验。尽管AI带来变革,但需结合人类创意与伦理监督,以促进内容产业健康发展。
412 3
|
算法 数据可视化 定位技术
【用unity实现100个游戏之16】Unity程序化生成随机2D地牢游戏1(附项目源码)
【用unity实现100个游戏之16】Unity程序化生成随机2D地牢游戏1(附项目源码)
259 0
|
SQL 弹性计算 Prometheus
统一观测丨使用 Prometheus 监控 E-MapReduce,我们该关注哪些指标?
统一观测丨使用 Prometheus 监控 E-MapReduce,我们该关注哪些指标?
728 83
统一观测丨使用 Prometheus 监控 E-MapReduce,我们该关注哪些指标?
|
存储 JavaScript 前端开发
javascript中字符串处理,常用的方法汇总
javascript中字符串处理,常用的方法汇总
181 0
|
分布式数据库 Hbase
HBase的数据删除是如何进行的?
HBase的数据删除是如何进行的?
571 0
|
分布式计算 NoSQL Java
大数据学习资料和书籍推荐
大数据学习资料和书籍推荐
383 0