zoukankan      html  css  js  c++  java
  • Python 实现找出所有水仙花数的方法

    水仙花数是指一个 3位正整数,它的每个位上的数字的 3 次幂之和等于它本身。(例如:1^3 + 5^3+ 3^3 = 153)

    下面用一句代码实现找出所有的水仙花数:

    方法一:

    >>>
    >>> a = list(map(lambda x: x[1], filter(lambda x: x[0], [(i*100+j*10+k == i**3+j**3+k**3, i**3+j**3+k**3) for i in range(1, 10) for j in range(0, 10) for k in range(0, 10)])))
    >>> print(a)
    [153, 370, 371, 407]
    >>>
     
    说明:

    上面的代码可以分解三句代码:

    a = [(i*100+j*10+k == i**3+j**3+k**3, i**3+j**3+k**3) for i in range(1, 10) for j in range(0, 10) for k in range(0, 10)]
    b = filter(lambda x: x[0], a)
    c = list(map(lambda x: x[1], b))
     
    第一句表示用列表推到遍历所有的三位数,每个数都打上标记,是水仙花数着标记True,不是则标记False,标记和数放到一个元祖:(flag, value),所有元组放在一个list结构里。

    第二句表示筛选出标记为True的元组。

    第三句表示把第一句筛选出来的元组的第二个值放到list结构里。

    加上print语句,执行一遍上面三句代码即可明白。

    方法二:

    只用列表推导。

    >>> a = [i**3+j**3+k**3 for i in range(1, 10) for j in range(0, 10) for k in range(0, 10) if i*100+j*10+k == i**3+j**3+k**3]
    >>> print(a)
    [153, 370, 371, 407]
    >>>
     
    非常感谢你的阅读
    ————————————————
    版权声明:本文为CSDN博主「adrrry」的原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接及本声明。
    原文链接:https://blog.csdn.net/adrrry/article/details/105693586

  • 相关阅读:
    Keepalived 无法自动转换主备角色,请关注 iptables 防火墙配置
    Linux 下使用网易的SMTP服务器 发送邮件
    Spring-boot 最小demo
    go build 时报错 cc1.exe: sorry, unimplemented: 64-bit mode not compiled in
    spark-shell 执行脚本并传入参数
    JVM
    spark
    spark
    linux
    linux
  • 原文地址:https://www.cnblogs.com/LQZ888/p/12768334.html
Copyright © 2011-2022 走看看