如何解决使用函数递归在 python 和行中添加数字
def add_sum(n):
numStr = str(n)
sum = 0
for i in range(len(num_str)):
sum += int(numStr[])
return sum
print(add_sum(546))
我希望答案是这样的。
输出:5 + 4 + 6 = 15
我怎样才能使这项工作适合我?
解决方法
add_sum = lambda number: sum([int(x) for x in str(number)])
如果你想做字符串转换的方式
编辑:当您提到“递归”时,我假设您指的是循环?
如果你想循环一个数字的数字,你也可以使用模块 10 并每次将数字相除。
,不将 int 转换为 str 的递归解决方案(这是一种昂贵的操作):
def add_sum(n):
return 0 if n == 0 else n % 10 + add_sum(n // 10)
如果您更喜欢没有递归的解决方案:
def add_sum(n):
result = 0
while n != 0:
result += n % 10
n //= 10
return result
如果要将 int 转换为 str:
def add_sum(n):
return sum(map(int,str(n)))
,
你可以试试这个
def add_sum(n):
numStr = str(n)
sum1 = 0
for i in range(len(numStr)):
sum1 += int(numStr[i])
return ' + '.join([str(x) for x in n]),sum1
i,j=add_sum('546')
print(i,'=',j)
,
def add_sum(n):
numStr = str(n)
sum = 0
for i in range(len(numStr)):
sum += int(numStr[i])
return sum
print(add_sum(546))
这是您代码的正确版本!
你可以像这样使用你的函数递归!
def add_sum(n,sum=0):
if n == 0:
return sum
else:
sum += n % 10
return add_sum(int(n/10),sum)
print(add_sum(546))
给你!溶胶。带递归
def add_sum(n,sum=0,orignal=0):
if n == 0:
return(f"{orignal} => {' + '.join(str(orignal))} = {sum}")
elif orignal == 0:
orignal = n
sum += n % 10
else:
sum += n % 10
return add_sum(int(n/10),sum,orignal)
print(add_sum(54236))
Output:
54236 => 5 + 4 + 2 + 3 + 6 = 20
,
你可以试试这个非递归代码。
def add_sum(n):
temp = list(str(n))
ans = 0
for i in temp:
ans += int(i)
print(f"{' + '.join(temp)} = {ans}")
for i in range(3):
num = int(input())
add_sum(num)
Output:
546
5 + 4 + 6 = 15
258
2 + 5 + 8 = 15
6985
6 + 9 + 8 + 5 = 28
,
这也有效
def add(num):
num_ = str(num)
if (len(num_) == 1):
return int(num)
else:
x = add(num_[1:])
return (x + int(num_[0]))
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。