编程实现打印输出100~1000之间的所有水仙花数。(注:水仙花数是指一个 n 位数 ( n≥3 ),它的每个位上的数字的 n 次幂之和等于它本身。php
时间: 2023-11-15 14:06:39 浏览: 99
以下是 PHP 代码实现:
```php
for ($i = 100; $i <= 1000; $i++) {
$sum = 0;
$num = $i;
$digits = strlen((string)$num);
while ($num > 0) {
$digit = $num % 10;
$sum += pow($digit, $digits);
$num = floor($num / 10);
}
if ($sum == $i) {
echo $i . " ";
}
}
```
该代码通过循环遍历100~1000之间的所有数,对于每个数计算其每位数字的n次幂之和,并与该数本身进行比较,如果相等则输出该数,即为水仙花数。
相关问题
编程实现打印输出100~1000之间的所有水仙花数。(注:水仙花数是指一个 n 位数 ( n≥3 ),它的每个位上的数字的 n 次幂之和等于它本身。
以下是 Python 代码实现:
```python
for i in range(100, 1000):
n = len(str(i))
s = 0
for digit in str(i):
s += int(digit) ** n
if s == i:
print(i)
```
输出结果为:
```
153
370
371
407
```
php编程实现打印输出100~1000之间的所有水仙花数。(注:水仙花数是指一个 n 位数 ( n≥3 ),它的每个位上的数字的 n 次幂之和等于它本身。
以下是使用 PHP 实现打印输出 100~1000 之间的所有水仙花数的代码:
```php
for ($i=100; $i<=1000; $i++) {
$sum = 0;
$num = "$i"; // 将数字转换为字符串
$len = strlen($num); // 获取数字的位数
// 计算每位数字的 n 次幂之和
for ($j=0; $j<$len; $j++) {
$sum += pow($num[$j], $len);
}
// 如果和等于该数字本身,则为水仙花数
if ($sum == $i) {
echo $i . "<br>";
}
}
```
输出结果为:
```
153
370
371
407
```
阅读全文