LeetCode每日一题——1780. 判断一个数字是否可以表示成三的幂的和

LeetCode每日一题系列

题目:1780. 判断一个数字是否可以表示成三的幂的和
难度:普通


文章目录

  • LeetCode每日一题系列
  • 题目
  • 示例
  • 思路
  • 题解


题目

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

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

示例

LeetCode每日一题——1780. 判断一个数字是否可以表示成三的幂的和_第1张图片

思路

这里不妨转变一下思路,3^0 、 3^1 乃至3^n可以看成三进制到十进制的转换,这里我们反过来考虑,将给定的十进制数转化为三进制,判断每一位数字是否为1或0,如果为则可以完成题中转换,如果不为则无法完成。

题解

class Solution:
    def checkPowersOfThree(self, n: int) -> bool:
        while n > 0:
            if n % 3 == 2:
                return False
            n //= 3
        return True

你可能感兴趣的:(#,算法实例,leetcode,算法,职场和发展,数据结构,python)