使用函数递归在 python 和行中添加数字
Adding numbers in python and in line using function recursion
大家好,我有这样的代码
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,每次除数。
你可以试试这个
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)
不将 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)
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]))
大家好,我有这样的代码
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,每次除数。
你可以试试这个
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)
不将 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)
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]))