水仙花数是指一个 n 位数(n≥3),它的每位上的数字的 n 次幕之和等于它本身。 例 如: 1^3+5^3+3^3 = 153。 求 100 ~ 999 之间所有的水仙花数。
时间: 2023-12-23 10:03:34 浏览: 159
可以使用循环遍历 100~999 之间的所有数,然后判断每个数是否为水仙花数,如果是,则将其加入结果列表中。判断一个数是否为水仙花数,可以将其各个位上的数字取出来,然后根据公式进行求幂和,最后与原数进行比较。
代码如下:
```python
res = []
for num in range(100, 1000):
s = str(num)
n = len(s)
sum = 0
for i in range(n):
sum += int(s[i]) ** n
if sum == num:
res.append(num)
print(res)
```
执行结果为:
```
[153, 370, 371, 407]
```
因此,100~999 之间所有的水仙花数为 153、370、371 和 407。
相关问题
水仙花数是指一个n位数(n≥3),它的每位上的数字的n次幂之和等于它本身。例如:1^3+5^3+3^3=153,求100-999之间所有的水仙花数。
可以使用循环来遍历100-999之间的所有数,然后计算每个数的每位数字的n次幂之和,判断是否等于该数本身。具体实现如下:
```python
for i in range(100, 1000):
# 将数字转化为字符串,方便提取每位数字
digits = str(i)
n = len(digits)
# 计算每位数字的n次幂之和
sum = 0
for digit in digits:
sum += int(digit) ** n
# 判断是否为水仙花数
if sum == i:
print(i)
```
运行上述代码,输出结果为:
```
153
370
371
407
```
因此,100-999之间所有的水仙花数为153、370、371和407。
水仙花数是指一个n位数(n≥3),它的每位上的数字的n次幂之和等于它本身。例如:13+53+33=153。求100~999之间所有的水仙花数。
好的,让我来回答您的问题。我们可以用循环来判断100到999之间的每个数是否为水仙花数,并将符合条件的数输出。以下是代码实现:
```python
for i in range(100,1000):
num_str = str(i)
sum = 0
for digit_str in num_str:
sum += int(digit_str) ** 3
if sum == i:
print(i)
```
输出结果为:
```
153
370
371
407
```
这四个数是100到999之间的所有水仙花数。
阅读全文