编写一个程序,判断一个数是否是水仙花数。
时间: 2024-11-09 18:25:33 浏览: 16
水仙花数是指一个三位数,其各位数字立方之和等于该数本身。例如,153就是一个水仙花数,因为1^3 + 5^3 + 3^3 = 1 + 125 + 27 = 153。
下面是一个简单的Python程序,用于检查一个整数是否是水仙花数:
```python
def is_armstrong_number(num):
# 将数字转换为字符串以便提取每一位
str_num = str(num)
# 确保数字有三位
if len(str_num) != 3:
return False
# 计算每一位数字的立方和
sum_of_cubes = sum(int(digit)**3 for digit in str_num)
# 比较立方和与原数是否相等
return sum_of_cubes == num
# 测试示例
number = int(input("请输入一个三位数: "))
if is_armstrong_number(number):
print(f"{number} 是水仙花数")
else:
print(f"{number} 不是水仙花数")
```
用户可以输入一个三位数,程序会判断它是否是水仙花数,并给出相应的结果。
相关问题
编写一个程序判断一个数是不是水仙花数
好的,这个问题我可以回答。水仙花数是指一个三位数,其各位数字的立方和等于该数本身。例如,153就是一个水仙花数,因为1的立方加上5的立方加上3的立方等于153。以下是一个判断一个数是否为水仙花数的Python程序:
num = int(input("请输入一个三位数:"))
sum = 0
temp = num
while temp > 0:
digit = temp % 10
sum += digit ** 3
temp //= 10
if num == sum:
print(num, "是水仙花数")
else:
print(num, "不是水仙花数")
请你编写一个程序判断一个数是不是水仙花数
好的,我可以回答这个问题。判断一个数是否为水仙花数,需要将这个数的每一位数的立方相加,如果结果等于这个数本身,那么这个数就是水仙花数。以下是一个简单的 C 语言程序实现:
#include <stdio.h>
int main() {
int num, originalNum, remainder, result = 0;
printf("请输入一个整数:");
scanf("%d", &num);
originalNum = num;
while (originalNum != 0) {
remainder = originalNum % 10;
result += remainder * remainder * remainder;
originalNum /= 10;
}
if (result == num)
printf("%d 是水仙花数", num);
else
printf("%d 不是水仙花数", num);
return 0;
}
阅读全文