使用函数递归在 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]))