Python递归时间复杂度

 更新时间:2022年03月18日 11:07:07   作者:chen_冲冲  
这篇文章主要介绍了Python递归时间复杂度,时间复杂度一般认为O(logn),但递归算法的时间复杂度本质上是要看递归的次数,每次递归中的操作次数,下面文章详细介绍,需要的朋友可以参考一下

递归也是常见算法之一,其时间复杂度一般认为O(logn),但递归算法的时间复杂度本质上是要看: 递归的次数 * 每次递归中的操作次数

举例面试题:求x的n次方

思路一:for循环

def x_n(x,n):
    """
    时间复杂度O(n)
    """
    if n==0:
        return 1
    
    return x*x_n(x,n-1)
    
if __name__=='__main__':
    print(x_n(2,0))
    print(x_n(2,3))
    print(x_n(2,4))

思路二:递归

但是递归时间复杂度未必更优,

比如:

def x_n(x,n):
    """
    时间复杂度O(n)
    """
    if n==0:
        return 1
    
    return x*x_n(x,n-1)
    
if __name__=='__main__':
    print(x_n(2,0))
    print(x_n(2,3))
    print(x_n(2,4))

也可以是:

def x_n(x,n):
    """
    时间复杂度O(n)
    """
    if n==0:
        return 1
    if n%2==1:
        return x*x_n(x,n//2)*x_n(x,n//2)
    
    else:
        return x_n(x,n//2)*x_n(x,n//2)
if __name__=='__main__':
    print(x_n(2,0))
    print(x_n(2,3))
    print(x_n(2,4))

如果面试官询问是否还可以优化?可思考的方向是递归模块提取出来。

def x_n(x,n):
    """
    时间复杂度O(logn)
    """
    if n==0:
        return 1
    t=x_n(x,n//2)
    #print("t:",t)
    if n%2==1:
        return x*t*t
    
    return t*t
if __name__=='__main__':
    print(x_n(2,0))
    print(x_n(2,3))
    print(x_n(2,4))

到此这篇关于Python递归时间复杂度的文章就介绍到这了,更多相关Python递归内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • python图像处理-利用一行代码实现灰度图抠图

    python图像处理-利用一行代码实现灰度图抠图

    这篇文章主要介绍了python图像处理-利用一行代码实现灰度图抠图,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-05-05
  • Django 实现 Websocket 广播、点对点发送消息的代码

    Django 实现 Websocket 广播、点对点发送消息的代码

    这篇文章主要介绍了Django 实现 Websocket 广播、点对点发送消息,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-06-06
  • 用Python生成HTML表格的方法示例

    用Python生成HTML表格的方法示例

    这篇文章主要介绍了用Python生成HTML表格的方法示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-03-03
  • Python使用itertools模块实现排列组合功能示例

    Python使用itertools模块实现排列组合功能示例

    这篇文章主要介绍了Python使用itertools模块实现排列组合功能,涉及Python基于itertools模块product、permutations与combinations_with_replacement方法进行排列、组合等相关操作实现技巧,需要的朋友可以参考下
    2018-07-07
  • Python中print()函数使用实例详解

    Python中print()函数使用实例详解

    Python的print()函数可以打印输出,常用来将内容打印到控制台,print()是python中最常见的一个函数,本文就通过一些实例来给大家讲讲如何使用print()函数,需要的朋友可以参考下
    2023-07-07
  • Python将8位的图片转为24位的图片实现方法

    Python将8位的图片转为24位的图片实现方法

    这篇文章主要介绍了Python将8位的图片转为24位的图片的实现代码,非常不错,具有一定的参考借鉴价值,需要的朋友可以参考下
    2018-10-10
  • Python3爬虫学习之将爬取的信息保存到本地的方法详解

    Python3爬虫学习之将爬取的信息保存到本地的方法详解

    这篇文章主要介绍了Python3爬虫学习之将爬取的信息保存到本地的方法,结合实例形式详细分析了Python3信息爬取、文件读写、图片存储等相关操作技巧,需要的朋友可以参考下
    2018-12-12
  • Python从临时邮箱获取验证码的操作代码

    Python从临时邮箱获取验证码的操作代码

    这篇文章主要介绍了Python从临时邮箱获取验证码的操作代码,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2023-08-08
  • Python3.遍历某文件夹提取特定文件名的实例

    Python3.遍历某文件夹提取特定文件名的实例

    下面小编就为大家分享一篇Python3.遍历某文件夹提取特定文件名的实例,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2018-04-04
  • 在Python中实现替换字符串中的子串的示例

    在Python中实现替换字符串中的子串的示例

    今天小编就为大家分享一篇在Python中实现替换字符串中的子串的示例,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2018-10-10

最新评论