【Python CheckiO 题解】Digits Multiplication


CheckiO 是面向初学者和高级程序员的编码游戏,使用 Python 和 JavaScript 解决棘手的挑战和有趣的任务,从而提高你的编码技能,本博客主要记录自己用 Python 在闯关时的做题思路和实现代码,同时也学习学习其他大神写的代码。

CheckiO 官网:https://checkio.org/

我的 CheckiO 主页:https://py.checkio.org/user/TRHX/

CheckiO 题解系列专栏:https://itrhx.blog.csdn.net/category_9536424.html

CheckiO 所有题解源代码:https://github.com/TRHX/Python-CheckiO-Exercise


题目描述

【Digits Multiplication】:给你一个正整数,请你写一个函数来实现:将正整数的每一位(不包括0)相乘,例如:给你 123405, 你应该这样处理 1*2*3*4*5=120(别忘了把0丢掉)。

【链接】https://py.checkio.org/mission/digits-multiplication/

【输入】:一个正整数

【输出】:正整数的每一位相乘后的结果

【范例】

checkio(123405) == 120
checkio(999) == 729
checkio(1000) == 1
checkio(1111) == 1

解题思路

先将给的整数转换成字符串形式,循环访问该字符串,如果值不为 0,就将该字符转化成整型,然后依次相乘即可。

代码实现

def checkio(number: int) -> int:
    num = 1
    for i in str(number):
        if i != '0':
            num *= int(i)
    return num


if __name__ == '__main__':
    print('Example:')
    print(checkio(123405))
    
    # These "asserts" using only for self-checking and not necessary for auto-testing
    assert checkio(123405) == 120
    assert checkio(999) == 729
    assert checkio(1000) == 1
    assert checkio(1111) == 1
    print("Coding complete? Click 'Check' to review your tests and earn cool rewards!")

大神解答

大神解答 NO.1

def checkio(number: int) -> int:
    if 0 < number < 10 ** 6:
        result = 1
        for n in str(number): 
            if n != '0':
                result = result * int(n)
    return result

大神解答 NO.2

from functools import reduce

def checkio(number: int) -> int:
    return reduce(lambda x,y: x*y, [int(i) for i in str(number).replace('0','')])

大神解答 NO.3

def checkio(number: int) -> int:
    r = 1
    while number:
        number, n = divmod(number, 10)
        if n: r *= n
    return r
发布了135 篇原创文章 · 获赞 468 · 访问量 43万+
展开阅读全文

没有更多推荐了,返回首页

©️2019 CSDN 皮肤主题: 数字20 设计师: CSDN官方博客

分享到微信朋友圈

×

扫一扫,手机浏览