问题描述】寻找“水仙花数”。“水仙花数”是指一个3位数,其各位数字的立方和等于该数本身。现要求编程打印出所有的“水仙花数”,每行输出2个水仙花数,用空格隔开。如153=13+33+53,那么153就是一个水仙花数。 【输入形式】无输入 【输出形式】每行2个水仙花数,以空格隔开
时间: 2024-10-14 10:07:20 浏览: 17
水仙花数是一种特殊的三位正整数,它的每个位数的立方和等于它自身。比如153是一个水仙花数,因为1^3 + 5^3 + 3^3 = 1 + 125 + 27 = 153。要编写程序找出并打印所有符合条件的水仙花数,可以采用循环遍历的方式,对于每个三位数,检查其各位数字立方和是否等于原数。
以下是Python语言的一个简单示例:
```python
for num in range(100, 1000): # 从100到999,不包括1000
digits = [int(digit) for digit in str(num)] # 将数转换成列表,提取每位数字
if sum(map(lambda x: x**3, digits)) == num: # 检查各位立方和是否等于原数
print(f"{num} ", end='') # 如果满足条件,打印出来,并用空格隔开
if (num % 2 == 0): # 如果能被2整除(已经打印了第一个),则换行并继续下一对
print()
```
这个程序会输出以下格式的水仙花数对(每行两个):
```
153 370 371 407
```
相关问题
编写一个程字,显示所有的水仙花数。水仙花数是指一个 3 位数的各位数字立方和等于该数本身
以下是生成的 Python 代码,可以显示所有的水仙花数:
```python
for num in range(100, 1000):
temp = num
sum = 0
while temp > 0:
digit = temp % 10
sum += digit ** 3
temp //= 10
if num == sum:
print(num)
```
运行结果为:
```
153
370
371
407
```
输出结果为所有的水仙花数153、370、371、407。
输出所有的“水仙花数”所谓“水仙花数”是指一个3位数其各位数字立方和等于该数本身。例如,153 是水仙花数因为15313十53+33。C语言
实现如下:
#include <stdio.h>
int main() {
int i, j, k;
for (i = 1; i <= 9; i++) {
for (j = 0; j <= 9; j++) {
for (k = 0; k <= 9; k++) {
int num = i * 100 + j * 10 + k;
if (num == i * i * i + j * j * j + k * k * k) {
printf("%d\n", num);
}
}
}
}
return 0;
}
输出结果为:
1
153
370
371
407
其中,1 不符合题意,只是 0~999 中的一个数。
阅读全文