python笔记:判断一个数是不是水仙花数(或者阿姆斯特朗数)

一时失言乱红尘 2022-04-25 06:38 277阅读 0赞

基本介绍:
如果一个n位正整数等于其各位数字的n次方之和,则称该数为阿姆斯特朗数。

例如1^3 + 5^3 + 3^3 = 153

当n=3时,又称水仙花数,特指一种三位数,其各个数之立方和等于该数。

水仙花数共有4个,分别为:153、370、371、407。

水仙花数只是自幂数的一种,严格来说3位数的3次幂数才称为水仙花数。

  1. # Python 检测用户输入的数字是否为阿姆斯特朗数
  2. # 获取用户输入的数字
  3. num = int(input("请输入一个数字: "))
  4. # 初始化变量 sum
  5. sum = 0
  6. # 每位数需要的指数
  7. n = len(str(num))
  8. # 检测
  9. temp = num
  10. while temp > 0:
  11. digit = temp % 10#digit取得temp位数的最后位
  12. sum += digit ** n
  13. temp //= 10#逐渐将个、十、百的位数去掉
  14. # 输出结果
  15. if num == sum:
  16. print(num,"是阿姆斯特朗数")
  17. else:
  18. print(num,"不是阿姆斯特朗数")

输出结果:

  1. 请输入一个数字: 153
  2. 153 是阿姆斯特朗数

发表评论

表情:
评论列表 (有 0 条评论,277人围观)

还没有评论,来说两句吧...

相关阅读

    相关

     /\ 功能: 求n(n ≤ 65536)以内的所有阿姆斯特朗数 阿姆斯特朗数:如果一个正整数等于其各个数字的立方和,     则该数称为阿姆斯特朗数(亦称为自