刷题之递归、非递归、尾递归

每天来公司来得早,天冷打不了球,就写写小算法吧

C语言头文件math.h 里面有一个pow(x, y)函数,就是x ^ y,用算法实现:

def power(x: int, y: int):
	if y == 0:
		return 1
	elif y == 1:
		return x
	ret = x
	while (y > 1):
		ret *= x
		y -= 1
	return ret

挺简单的。加入限制条件,O(logn)时间复杂度,O(1)空间复杂度,使用递归与非递归方式实现。

一般logn的时候,就一定会想 >> 1 这种,比如普通直给方式采用的是 O(n)的方式实现,那么比如 2¹² 就是 3次循环搞定。

def power_recursion(x: int, y: int) -> int:
	if y == 0:
		return 1
	ret = power_recursive(x, int(y / 2)) * power_recursive(x, int(y / 2))
	if y & 1:
		return x * ret
	else:
		return ret

def power_tail_recursion(x: int, y: int, ret: int) -> int:
	if y == 0:
		return ret
	if y & 1: # odd
		ret *= x
	y >>= 1
	x *= x
	return power_tail_recursive(x, y, ret)


def power_no_recursion(x: int, y: int) -> int:
	ret = 1
	while y > 0:
		if y & 1: # odd
			ret *= x
		y >>= 1
		x *= x
	return ret
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值