小李飞刀:leetcode我又来啦~

栏目: 编程工具 · 发布时间: 6年前

内容简介:年前嘛,就是各种涣散的状态。在拖完地板之后,想想还是补上今天的题解吧~感谢小佳扬推荐的题目,默默的复习了一把递归~

写在前面

年前嘛,就是各种涣散的状态。

在拖完地板之后,想想还是补上今天的题解吧~

感谢小佳扬推荐的题目,默默的复习了一把递归~

第一题

50. Pow(x, n)

难度:中等

实现 pow(x, n) ,即计算 x 的 n 次幂函数。

我的解题代码:

class Solution:
    def myPow(self, x, n):
        """
        :type x: float
        :type n: int
        :rtype: float
        """
        if not n:
            return 1
        if n < 0 :
            return 1 / self.myPow(x, -n)
        if n % 2:
            return x * self.myPow(x, n-1)
        return self.myPow(x*x, n/2)

参考了部分评论区的题解。

效率上还是可以的,复杂度在N(logn)左右。

小李飞刀:leetcode我又来啦~

我的解题思路:

一开始的时候小佳扬说是坑,我还在想不就是循环么。

后来她说要考虑怎么降低复杂度,否则会超时,就开始认真的思考了。

  • 因为是n次幂,如果直接循环,复杂度就是O(n)了。
  • n次幂可以拆解为n/2 n 2的方式。
  • 考虑n为偶数和奇数的情况,判断余数后进行计算即可。
  • 每次拆解n/2,最后最小的单位应该为x*x。
  • 因为每一轮都为前一轮的解的2次方,所以用递归。

总结:

递归还是比较绕的,前提是要找到每一次循环的出口,否则极容易变成死循环。

马上放假了~

统计学+算法+数据结构还是会常伴左右的~

最近还加上了托福的单词,因为受到了单词量统计的刺激,我居然现在知晓的单词量只有3k了,要抓紧背起来了~

自律使我快乐~


以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

跨境电商——阿里巴巴速卖通宝典

跨境电商——阿里巴巴速卖通宝典

速卖通大学 编著 / 电子工业出版社 / 2015-1 / 69.00元

跨境电商作为中国电子商务发展的最新趋势,受到了全社会越来越多的重视,大量中国卖家借助阿里巴巴速卖通平台,将产品直接售卖到全球的消费者手中,通过这条短得不能再短的交易链,获得了丰厚的回报。 但同时,跨境电商这一贸易形式,对卖家的综合素质要求比较高:卖家要对海外市场比较熟悉,对跨境物流有所把握,能够用外语进行产品介绍和客户交流,通过跨境结算拿到货款……诸如此类的门槛,让不少新卖家心生畏难,而所有......一起来看看 《跨境电商——阿里巴巴速卖通宝典》 这本书的介绍吧!

图片转BASE64编码
图片转BASE64编码

在线图片转Base64编码工具

随机密码生成器
随机密码生成器

多种字符组合密码

RGB CMYK 转换工具
RGB CMYK 转换工具

RGB CMYK 互转工具