![](/img/trans.png)
[英]How would i make my python code below more efficient and simple for this recursive function?
[英]How would you make the following doubling function more efficient and cleaner?
我刚刚写了一个简单的 function ,它采用任何 integer 并不断总结其中的所有数字,直到它达到一个数字的长度。 我想知道是否有更好的方法来重新格式化 function?
def summing(number):
number_length = len(str(number))
sum_of_digits = number
while number_length > 1:
sum_of_digits = 0
for digit in str(number):
sum_of_digits += int(digit)
number_length = len(str(sum_of_digits))
number = sum_of_digits
return sum_of_digits
例子:
number = 132456 => 1+3+2+4+5+6 => 4+6+5+6 => 10 + 11 => 1 + 2 => 3
我会使用cast out Nines来编写它:
def summing(number):
return number % 9 or 9
number = 132456
summing(number)
# 3
...假设一个大于零的数字。
如果您希望它处理所有整数,则需要处理零并通过取绝对值( abs()
)将负数转换为正数。
def summing(number):
if number == 0: return 0
return abs(number) % 9 or 9
number = -1234
summing(number)
# 1
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.