牛客网求将输入的一个数进行多少次变换变成个位数的次数python解法(递归方法

系统 1836 0

题目描述:

牛牛想对一个数做若干次变换,直到这个数只剩下一位数字。 
变换的规则是:将这个数变成 所有位数上的数字的乘积。比如285经过一次变换后转化成2*8*5=80. 
问题是,要做多少次变换,使得这个数变成个位数。

输入描述: 
输入一个整数。小于等于2,000,000,000。

输出描述: 
输出一个整数,表示变换次数。

输入例子: 
285

输出例子: 

 

我的代码:

            
              #coding=utf-8

# 求将输入的一个数进行多少次变换变成个位数的次数
def zhuanhuan(input_a,temp):
    input_a = str(input_a)
    k = int(input_a[0])
    for i in range(1, len(input_a)):
        #把大于10的数拆分为各个位数乘的新数
        k *= int(input_a[i])
    temp += 1
    #求新数// 10 的整数商,如果为0说明新数已经是个位数,return出temp
    if k // 10 == 0:
        return temp
    else:#如果不是,则递归继续转换
        return zhuanhuan(k, temp)



input_a = int(input())
#计数器变量--是公共变量放在函数外面,初始值是0
temp = 0
if input_a < 10:
    print(0)
else:
    ret = zhuanhuan(input_a,temp)
    print(ret)
            
          

测试用例:

牛客网求将输入的一个数进行多少次变换变成个位数的次数python解法(递归方法使用)_第1张图片

说明:我的用例是用python3.5版本实现的,如果python是2.7版本则要按py2版本写


更多文章、技术交流、商务合作、联系博主

微信扫码或搜索:z360901061

微信扫一扫加我为好友

QQ号联系: 360901061

您的支持是博主写作最大的动力,如果您喜欢我的文章,感觉我的文章对您有帮助,请用微信扫描下面二维码支持博主2元、5元、10元、20元等您想捐的金额吧,狠狠点击下面给点支持吧,站长非常感激您!手机微信长按不能支付解决办法:请将微信支付二维码保存到相册,切换到微信,然后点击微信右上角扫一扫功能,选择支付二维码完成支付。

【本文对您有帮助就好】

您的支持是博主写作最大的动力,如果您喜欢我的文章,感觉我的文章对您有帮助,请用微信扫描上面二维码支持博主2元、5元、10元、自定义金额等您想捐的金额吧,站长会非常 感谢您的哦!!!

发表我的评论
最新评论 总共0条评论