开发者

Python递归时间复杂度

开发者 https://www.devze.com 2022-12-13 11:19 出处:网络 作者: chen_冲冲
目录思路一:for循环思路二:递归递归也是常见算法之一,其时间复杂度一般认为O(logn),但递归算法的时间复杂度本质上是要看: 递归的次数 * 每次递归中的操作次数
目录
  • 思路一:for循环
  • 思路二:递归

递归也是常见算法之一,其时间复杂度一般认为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))
  printhttp://www.cppcns.com(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(xwww.cppcns.com,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))
  tsTFRyNveprint(x_n(2,3))
  print(x_n(2tsTFRyNve,4))

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

0

精彩评论

暂无评论...
验证码 换一张
取 消