如果您想用数字表示,请考虑以10为基数的数字的含义:145 = 1 * 10**2 + 4 * 10**1 + 5 * 10**0
所以,你需要得到N-1到0的N个数字,与数字同步。一种方法是使用enumerate加上一些额外的运算:
^{pr2}$
现在:>>> add_digits(1, 4, 5)
145
当然,这只适用于你事先知道有多少位数的数字序列。如果你想处理任何一个iterable的数字,甚至是一个迭代器来生成一个表达式或什么的呢?然后你可以重新考虑这个问题:1456 = ((1 * 10 + 4) * 10 + 5) * 10 + 6
所以:def add_digits(digits):
total = 0
for digit in digits:
total = total * 10 + digit
return total
>>> add_digits((1, 3, 5, 6))
1356
>>> add_digits(n for n in range(10) if n%2)
13579
请注意,您可以轻松地将任一版本扩展到其他基础:def add_digits(*digits, base=10):
total = 0
for i, digit in enumerate(digits):
total += digit * base**(len(digits)-i-1)
return total
>>> hex(add_digits(1, 0xF, 2, 0xA, base=16))
'0x1f2a'
…对于stringy版本,这并不是很容易实现的;您不能只做int(''.join(map(str, digits)), base),而是需要用一个转换为给定基中字符串的函数来替换{