键盘输入一个数,判断这个数是否是水仙花数。所谓水仙花数,即这样的一个但三位数,每一个位上的数字的立方和等于这个三位数。c语言
时间: 2024-05-29 19:09:37 浏览: 50
实现如下:
#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 是水仙花数\n", num);
} else {
printf("%d 不是水仙花数\n", num);
}
return 0;
}
相关问题
2.键盘输入个数,判断这个数是否是水仙花数。所谓水仙花数,即这样的一个但三位数,每-一个位上的数字的立方和等于这个三位数。
n = int(input("请输入一个三位数:"))
a = n // 100 # 获取百位数
b = (n // 10) % 10 # 获取十位数
c = n % 10 # 获取个位数
if n == a**3 + b**3 + c**3:
print(n, "是水仙花数")
else:
print(n, "不是水仙花数")
从键盘上输入一个三位数,判断该数是否为水仙花数。所谓水仙花数是指一个三位数,其各位数字的立方和等于该数。
水仙花数是指一个三位数,它的百位、十位和个位数分别的立方之和恰好等于原数本身。例如,153就是一个水仙花数,因为1^3 + 5^3 + 3^3 = 1 + 125 + 27 = 153。
判断一个数是否为水仙花数的步骤通常是这样的:
1. 接收用户输入的三位数作为整数。
2. 分别计算这三个位数(百位、十位和个位)的立方。
3. 将这三个立方相加,如果结果等于原始的三位数,那么这个数就是水仙花数;否则就不是。
下面是一个简单的Python代码示例:
```python
def is_armstrong_number(num):
# 提取每一位
num_str = str(num)
first_digit = int(num_str[0])
second_digit = int(num_str[1])
third_digit = int(num_str[2])
# 计算立方和
sum_of_cubes = first_digit**3 + second_digit**3 + third_digit**3
# 比较立方和与原始数是否相等
return sum_of_cubes == num
# 用户输入
num = input("请输入一个三位数: ")
if is_armstrong_number(int(num)):
print(f"{num} 是一个水仙花数")
else:
print(f"{num} 不是水仙花数")
```
阅读全文