[python语法巩固][leetcode326][Power of Three]

题目大意

让你判断一个int是否为3的幂;

最简单的思路

C++

class Solution {
public:
    bool isPowerOfThree(int n) {
        for(long long i=1;i<=n;i=i*3LL)
        {
            if(i==n) return true;
        }
        return false;
    }
};

Python

第一种写法…很低效..因为不会类似C++的for..

class Solution(object):
    def isPowerOfThree(self, n):
        """
        :type n: int
        :rtype: bool
        """
        for x in range(30):
            if 3**x==n:
                return True;
        return False;

第二种写法 类似C++的,但是只用用while实现
Python的缩进真是让人理解不能 空格TAP混用不行??????
需要修改Sublime的设置

class Solution(object):
    def isPowerOfThree(self, n):
        x=1;
        while x <= n:
            if x==n :
                return True;
            x=x*3;
        return False;

sublime设置

sublime 默认是tab 缩进,修改成4个空格缩进 “首选项” —>”设置–更多” —>’”特定的语法–用户”
添加如下内容 点击(此处)折叠或打开 {
“tab_size”: 4,
“translate_tabs_to_spaces”: true }

要求不准用循环

1.利用对数函数,再判断是否为整数。

C++

精度误差要控制的很细 1e-10才能过,这样的程序速度快,但是存在一定误差。
注意取整的时候要加一个0.5才是 四舍五入!!!刘书上说过。

class Solution {
public:
    bool static isPowerOfThree(int n) {
        double a=log(n)/log(3);
        printf("%lf\n",a);
        int b=(int)(a+0.5);
        printf("%d\n",b);
        if(abs(a-b)<1e-10) return true;
        else return false ;
    }
};

Python

round(val,位数) 四舍五入
Python 中math.log() 接收到0会报错

class Solution(object):
    def isPowerOfThree(self, n):
        if n>0:
            a=math.log(n)/math.log(3.0);
        else :
            a=0.5;
        b=round(a,0)
        if abs(a-b)<1e-10:
            return True;
        else:
            return False;

终极想法

还有一种想法就是Python打表 switch ,应该是最简单的了。

转载于:https://www.cnblogs.com/zy691357966/p/5480295.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值