wy的leetcode刷题记录_Day59
声明
本文章的所有题目信息都来源于leetcode
如有侵权请联系我删掉!
时间:2022-12-9
前言
1780. 判断一个数字是否可以表示成三的幂的和
今天的每日一题是:1780. 判断一个数字是否可以表示成三的幂的和
题目介绍
给你一个整数 n ,如果你可以将 n 表示成若干个不同的三的幂之和,请你返回 true ,否则请返回 false 。
对于一个整数 y ,如果存在整数 x 满足 y == 3x ,我们称这个整数 y 是三的幂。
示例 1: 输入:n = 12
输出:true
解释:12 = 31 + 32
示例 2:
输入:n = 91
输出:true
解释:91 = 30 + 32 + 34
思路
方法一:分析题目,可知本题是求y是否能被不同的三的幂的和组成。y的取值在10的七次方范围内,小于3的二十次方。于是我选择使用一个数组来存3的0-19次方的值,然后根据贪心法,从后向前遍历,判断其是否能为符合题意的组成条件。最后判断选择的数的和是否为y即可。(其实这里还可以再简化一下,不用规定20次方这么死,y的值小于3的n次方时,用这个n即可)。
方法二(参考题解):数学分析法:我们可以将y看做成三进制表示,我们知道三进制表示的数每一个数位上的值表示多少个这个数位次方组成,当这个数字是0和1的时候是被允许的,而2的时候就不符合题意了(若干个不同…),所以我们仅需要判断三进制组成中的每一个数位是否出现2,如果是2那么返回false,如果不是那么返回true。
代码
贪心法:
class Solution {
public:
bool checkPowersOfThree(int n) {
// if(n%3!=0)
// return false;
int loop_num=20;
vector<int> quare_3(loop_num);
for(int i=0;i<loop_num;i++)
{
quare_3