递归应用之求和、进制转换Python

递归应用之求和、进制转换

1.求和:给出一个列表,用递归的方式求和。
其实求和也是两个数相加,然后再相加,直到求和完毕。所以可以用递归的方式,每次调用求和函数,直到列表中的数字还有一个,返回即可。

def resum(lists):
	if len(lists) == 1:
		return lists[0]
	else:
		return lists[0] + resum(lists[1:])

2.进制转换:进制转换即10进制转换成任意进制。在数学中就是除n取余法,余数逆序排列即可。那么什么时候结束呢,即什么时候不再取余呢?当商为0时(也就是此时的被除数小于除数,即小于进制),为最后一个取余操作。因为是余数相连,所以这里需要字符串转换。

def recurives(n, base):
    strs = '0123456789ABCDEF'
    if n < base:
        return strs[n]
    else:
        return recurives(n // base, base) + strs[n % base]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值