递归数字总和

在这里插入图片描述

def digital_root(num):
    if len(str(num))==1:
        print('=>',num)
        
    else:
        arr=list(str(num))
        print('=>','+'.join(arr))
        s=sum(map(int,arr))#map(函数,序列)对序列中的每个元素进行相应的函数操作
                           #此处把字符串的各个元素转化为整型
        #s=list(map(int,arr))  #[2, 2, 2, 3, 4, 5]
        
    
    
        if len(str(s))>1:
            print('=>',s,'...')
        digital_root(s)    #递归
    
    
digital_root(222345)

# => 2+2+2+3+4+5
# => 18 ...
# => 1+8
# => 9
解法二
def digital_root1(num):
    str_num=str(num)
    if len(str_num)==1:
        return str_num
    else:
        return digital_root1(sum([int(i) for i in str_num]))
    
digital_root(222345)
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值