如果一个 n 位正整数等于其各位数字的 n 次方之和,则称该数为阿姆斯特朗数。 例如 1^3 + 5^3 + 3^3 = 153。

1000 以内的阿姆斯特朗数: 1, 2, 3, 4, 5, 6, 7, 8, 9, 153, 370, 371, 407。 请编写程序,检测用户输入的数字是否为阿姆斯特朗数。

i = input("请输入与一个正整数:")
sum = 0
value = len(i)
for j in range(value):
    sum += int(i[j])**value
if sum == int(i):
    print(f"数值{i}是阿姆斯特朗数")
else:
    print(f"数值{i}不是阿姆特朗数")

# 法二:
# 获取用户输入的数字
num = int(input("请输入一个数字: "))
# 初始化变量 sum
sum = 0
# 指数
n = len(str(num))
# 检测
temp = num
while temp > 0:
    digit = temp % 10
    sum += digit ** n
    temp //= 10
# 输出结果
if num == sum:
    print(num, "是阿姆斯特朗数")
else:
    print(num, "不是阿姆斯特朗数")

你可能感兴趣的:(python题库)